Angular7(如下简称ng7),已经跟以前版本大有不一样。新建工程后,可方便建立library(简称lib),lib是什么呢?就是一个npm包的源码包。npm做为强大的包管理器,已经成为不少FEer分享智慧成果的法器。本文主要介绍本人写的一个radio组件。html
// 安装ng cli npm install -g @angular/cli // 新建工程 ng new ng-project // 进入ng-project 建立一个lib ng generate library radio
<!--说明:这实际上是一个radio-group 由于radio通常都是分组使用,这里有几个注意点 一、组内radio的name属性保持一致、组外保持惟一 二、经过checked属性来设置radio的选中状态,必定不要写成[attr.checked]--> <div class="input-wrap" [class.hor]="horizontal"> <div class="custom-radio" *ngFor="let item of data; let i=index"> <input #input class="custom-input" [name]="name" id="{{'radio_'+name+i}}" type="radio" [value]="item.value" (click)="clickHandler(item.value)" [checked]="item.value === value" [disabled]="disabled"> <label class="custom-label" for="{{'radio_'+name+i}}">{{item.name}}</label> </div> </div>
export class RadioGroupComponent implements ControlValueAccessor { /* radio 数组 */ @Input() data: Radio[] = []; /* radio 类型 原生或者按钮类型*/ @Input() type: string; /* name标识 */ @Input() name: string = this.idSer.generate().replace(/-/g, '_'); /* 水平排列 */ @Input() horizontal: boolean; /* 禁用 */ @Input() disabled: boolean; /* radio 值 */ @Input() value: any; constructor(private idSer: IdService) { } clickHandler(val: any) { this.value = val; // 更改control的值 this.controlChange(this.value); this.controlTouch(this.value); } writeValue(value: any): void { this.value = value; } registerOnChange(fn: Function): void { this.controlChange = fn } registerOnTouched(fn: Function): void { this.controlTouch = fn } private controlChange: Function = () => { } private controlTouch: Function = () => { } }
这是ng的一个forms API,能够方便原生DOM和ng forms传值。在组件元数据中这样定义npm
@Component({ selector: 'radiogroup', templateUrl: './radiogroup.component.html', providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RadioGroupComponent), multi: true, }] })
的数组
注意,是重写一个仍是都要重写。本组件两个方法都重写了,由于值变动的时机自定义成了blur。ide