我有兩個單選按鈕(他們沒有動態生成):角2:默認單選按鈕選擇
<input type="radio" name="orderbydescending" [(ngModel)]="orderbydescending" [value]="['+recordStartDate']">Ascending<br>
<input type="radio" name="orderbydescending" [(ngModel)]="orderbydescending" [value]="['-recordStartDate']">Descending
如何使默認選中的單選按鈕中的一個?
謝謝!
編輯
按鈕的價值觀正在通過該配管(即不是一個組成部分,本身......不知道這是值得一提的?)。該應用程序非常簡單,單選按鈕只是硬編碼到app.component。管道是否是初始化默認選中哪個單選按鈕的正確位置?
import { Pipe, PipeTransform } from '@angular/core';
@Pipe({name: 'orderBy', pure: false})
export class OrderByPipe implements PipeTransform {
static _OrderByPipeComparator(a:any, b:any):number{
if((isNaN(parseFloat(a)) || !isFinite(a)) || (isNaN(parseFloat(b)) || !isFinite(b))){
//Isn't a number so lowercase the string to properly compare
if(a.toLowerCase() < b.toLowerCase()) return -1;
if(a.toLowerCase() > b.toLowerCase()) return 1;
}
else{
//Parse strings as numbers to compare properly
if(parseFloat(a) < parseFloat(b)) return -1;
if(parseFloat(a) > parseFloat(b)) return 1;
}
return 0; //equal each other
}
transform(input:any, [config = '+']): any{
if(!Array.isArray(input)) return input;
if(!Array.isArray(config) || (Array.isArray(config) && config.length == 1)){
var propertyToCheck:string = !Array.isArray(config) ? config : config[0];
var desc = propertyToCheck.substr(0, 1) == '-';
//Basic array
if(!propertyToCheck || propertyToCheck == '-' || propertyToCheck == '+'){
return !desc ? input.sort() : input.sort().reverse();
}
else {
var property:string = propertyToCheck.substr(0, 1) == '+' || propertyToCheck.substr(0, 1) == '-'
? propertyToCheck.substr(1)
: propertyToCheck;
return input.sort(function(a:any,b:any){
return !desc
? OrderByPipe._OrderByPipeComparator(a[property], b[property])
: -OrderByPipe._OrderByPipeComparator(a[property], b[property]);
});
}
}
else {
//Loop over property of the array in order and sort
return input.sort(function(a:any,b:any){
for(var i:number = 0; i < config.length; i++){
var desc = config[i].substr(0, 1) == '-';
var property = config[i].substr(0, 1) == '+' || config[i].substr(0, 1) == '-'
? config[i].substr(1)
: config[i];
var comparison = !desc
? OrderByPipe._OrderByPipeComparator(a[property], b[property])
: -OrderByPipe._OrderByPipeComparator(a[property], b[property]);
//Don't return 0 yet in case of needing to sort by next property
if(comparison != 0) return comparison;
}
return 0; //equal each other
});
}
}
編輯2
所以在component.app.ts
我已經編輯我的export class AppComponent{
以下幾點:
export class AppComponent {
artists = ARTISTS;
currentArtist: Artist;
orderbydescending = ['-recordStartDate'];
showArtist(item) {
this.currentArtist = item;
}}
這工作防止以前的條款錯誤,但實際上並沒有選中單選按鈕。它仍然看起來好像沒有被選中 - 儘管它的功能就像它一樣。這有意義嗎?
這是你的意思嗎? '@Component({0}選擇器:'app', templateUrl:'../partials/app.html', styleUrls:['../css/app.css'], orderbydescending:boolean = true; })'如果是這樣,編譯時出現以下錯誤:'orderbydescending:boolean; }'不能分配給'Component'類型的參數。 對象字面量只能指定已知屬性,而'orderbydescending'不存在於類型'Component'中。「也許我誤解了。 (此外,單選按鈕的值確實是正確的,值是不同的,「+」v「 - 」。 – Boosman
看看我添加到我的答案。這是一個語法的東西。你可能需要看更多的例子Angular代碼這是Angular人寫的一本很好的指南,也是我開始寫的。https://angular.io/tutorial – SaxyPandaBear
是的 - 你是對的!我是Angular的新手,我匆忙同時,我已經更新了我的問題,包括傳遞無線電值的管道,包括'orderbydescending = ['+ recordStartDate'];'在管道內 – Boosman