Angular 2:默认单选按钮选择

时间:2017-07-03 21:16:18

标签: javascript html angular radio-button checked

我有两个单选按钮(它们不是动态生成的):

<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;

}  }

这可以防止以前的错误,但它实际上并没有选择单选按钮。它似乎仍未被选中 - 尽管它的功能就像它一样。这有意义吗?

3 个答案:

答案 0 :(得分:1)

如果您使用双向绑定在Angular 2+中执行此操作,则在使用此HTML的组件中,您可以尝试初始化与输入关联的值。

 awk '$2 ~ /^exon [0-9][0-9] sequence$/' file

你可以让HTML保持不变。虽然,您似乎有2个单选按钮与相同的数据值关联,orderbydescending。我不知道这是否符合您的意图,但看起来可能会导致问题。

这是我个人方面的一些代码,可以让你有更好的想法。

// in your component ts file
orderbydescending: boolean = true;

答案 1 :(得分:1)

在组件中尝试此操作

radioValue = {valueAsc: 'Asc', valueDesc: 'Desc'} ;
orderbydescending = 'Asc';

并在模板中放置此

<input type="radio" name="radioGroup" [(ngModel)]="orderbydescending" [value]="radioValue.valueAsc">Ascending

<input type="radio" name="radioGroup" [(ngModel)]="orderbydescending" [value]="radioValue.valueDesc">Descending

如果您不想选择任何单选按钮,则会选中第一个单选按钮,指定变量orderbydescending null。

orderbydescending = 'null;

答案 2 :(得分:1)

如果orderbydescendingrecordStartDate是您的组件类的成员:

@Component({
    ...
})
export class MyComponent {
    public recordStartDate: any = ... 
    public orderbydescending: any = +recordStartDate;
    ...
}

如果您使用[value]

指定单选按钮值,则会检查相应的单选按钮
<input type="radio" name="order" [(ngModel)]="orderbydescending" [value]="+recordStartDate">Ascending<br>
<input type="radio" name="order" [(ngModel)]="orderbydescending" [value]="-recordStartDate">Descending

在上面显示的情况下,默认情况下将检查升序单选按钮,因为orderbydescending变量最初设置为+recordStartDate

注意:我的示例代码中的变量属于any类型,因为我不确切知道您使用的是哪种数据。您的数据可能具有更具体的数据类型。