angular基于ng-alain定义自己的select组件示例
1、首先是my-select2.component.html页面,这里是在ng-alain的select基础上根据业务需求添加新的功能;代码如下:
2、再者是my-select2.component.ts页面,代码里面有注释;代码如下:
import{ControlValueAccessor}from'@angular/forms/src/directives'; import{Component,forwardRef,Input,OnInit,ElementRef,Output,EventEmitter}from'@angular/core'; import{NG_VALUE_ACCESSOR}from'@angular/forms'; import{Router,NavigationEnd}from'@angular/router'; import{FormGroup,FormBuilder,Validators}from'@angular/forms'; import{SelectService}from'./my-select2.service'; declarevar$:any; @Component({ selector:'nz-select2', templateUrl:'./my-select2.component.html', providers:[ { provide:NG_VALUE_ACCESSOR, useExisting:forwardRef(()=>NzSelect2Component),//注入表单控件 multi:true }] }) exportclassNzSelect2ComponentimplementsOnInit{ constructor(privateselectService:SelectService){ } innerValue:any=''; //监听绑定的值,与外岑的ngModel相互绑定 setselectedOption(val:any){ if(val!==this.innerValue){ this.innerValue=val; this.onChangeCallback(val.value); this.dataBack.emit(val.value);//事件 } } getselectedOption():any{ returnthis.innerValue; } options=[];//接收select的数组 _dataSource:any;//接收本地的自定义数组或者请求返回的数组 @Input() url:any;//请求的url @Input() myPlaceHolder:any;//自定义的PlaceHolder @Input() //下拉框的数据格式 fieldKey:any={ text:'text', value:'value' }; @Input() setdataSource(val:any){ this._dataSource=val; if($.isArray(this._dataSource)){ this.options=this._dataTransform(this._dataSource);//如果是本地数组或直接请求的数组直接复制 } } getdataSource():any{ returnthis._dataSource; } @Output()dataBack=newEventEmitter(); registerOnChange(fn:(value:any)=>void){ this.onChangeCallback=fn; } registerOnTouched(fn:any){ this.onTouchedCallback=fn; } writeValue(value:string){ } onChangeCallback=(value:any)=>{}; onTouchedCallback=(value:any)=>{}; ngOnInit(){ //如果url存在则直接请求 if(this.url){ this.selectService.getValue(this.url).subscribe(data=>{ data=data.rows||data.data; this.options=this._dataTransform(data); }); } } //转换下拉框下的字段 _dataTransform(data:Array ){ let_data=[]; for(leti=0;i 3、然后是my-select2.service.ts页面,这里主要是请求后台接口返回的下拉数组,url为父组件传过来的链接,代码如下:
import{Injectable}from'@angular/core'; import{Headers,Http,URLSearchParams,RequestOptions}from'@angular/http'; import{HttpClient,HttpErrorResponse}from'@angular/common/http'; import'rxjs/add/operator/toPromise'; //import{environment}from'../../environments/environment'; @Injectable() exportclassSelectService{ constructor(privatehttp:HttpClient){} getValue(url:any):any{ returnthis.http .get(url); } }4、然后是myselect.module.ts页面,这里,使用该组件的前提是要引入import{NzSelectModule}from'ng-zorro-antd',代码如下:
import{NgModule,ModuleWithProviders}from'@angular/core'; import{CommonModule}from'@angular/common'; import{FormsModule,ReactiveFormsModule}from'@angular/forms'; import{NzSelect2Component}from'./my-select2.component'; import{SelectService}from'./my-select2.service'; import{NzSelectModule}from'ng-zorro-antd'; @NgModule({ imports:[ CommonModule, FormsModule, NzSelectModule, ReactiveFormsModule ], exports:[ NzSelect2Component ], declarations:[ NzSelect2Component ], providers:[ SelectService ] }) exportclassMySelectModule{ constructor(){ } }5、使用方法,在你需要的模块引入:MySelectModule
import{MySelectModule}from'bizapp/base/components/myselect/myselect.module';6、如何调用:url为请求后台的接口,fieldKey为数组的格式,这里可以根据后台返回来的格式定义这里的字段,如:后台返回格式为[{dmsm1:5,dmz:5}]则fieldKey的定义如下,myPlaceHolder为初始化时显示的内容,如果是本地数组,则只需要加上[dataSource]="peer",这里的peer为本地数组
7、总结:通过这个组件,我们只需要修改url和fieldKey就可以在任意模块引入然后使用,减少代码的使用,方便维护
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。