国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Angular6 寫一個簡單的Select組件示例

2019-11-19 13:12:50
字體:
來源:轉載
供稿:網友

Select組件目錄結構

/src  /app    /select    /select.ts    /select.html    /select.css    /options.ts    /index.ts
//select.tsimport { Component, ContentChildren, ViewChild, Input, Output, EventEmitter, QueryList, HostListener } from '@angular/core';import { NzOptionDirective } from './option';@Component({ selector: 'nz-select', templateUrl: './select.html', styleUrls: ['./select.css']})export class NzSelectComponent { @Input() isOpen: boolean; @Input() value: string; @Output() valueChange = new EventEmitter<any>(); label: string; @ContentChildren(NzOptionDirective, { descendants: true }) options: QueryList<NzOptionDirective>; ngAfterContentInit() {  this.options.forEach(option => {   option.select.subscribe(() => {    this.value = option.value;    this.label = option.renderLabel();    this.options.map(r => r.isSelected = false);    option.isSelected = true;    this.valueChange.emit(option.value);   })   setTimeout(() => {    option.isSelected = option.value === this.value;    if (option.isSelected) {     this.label = option.renderLabel();     this.valueChange.emit(option.value);    }   });  }) } @HostListener('click') onClick() {  this.isOpen = !this.isOpen; }}
//select.html<ng-content *ngIf="isOpen"></ng-content><div *ngIf="!isOpen">{{label}}</div>
//select.css:host { display: inline-block; border: 1px solid; cursor: pointer; text-align: center; border-radius: 4px;}:host .current{ padding:5px 10px; background:red; color:#FFF; text-align: center; width:40px; outline: none; border: none;}::ng-deep div:not(.current):hover{ background:green; color:#FFF;}::ng-deep .selected { font-weight: 700; background: red; color:#FFF;}
//options.tsimport { Directive,HostBinding,HostListener,Input,Output,ElementRef,EventEmitter} from '@angular/core';@Directive({ selector:'[nzOption]'})export class NzOptionDirective{ @Input() value:string; constructor(private el:ElementRef){} @Output() select = new EventEmitter<any>();  @HostBinding("class.selected") isSelected: boolean; renderLabel(){  return (this.el.nativeElement.textContent || "").trim(); } @HostListener('click') onClick(){  this.select.emit(); }}
//index.tsimport { NzOptionDirective } from './option';import { NzSelectComponent } from './select';export const components = [ NzSelectComponent, NzOptionDirective];

應用 Select 組件

結構

/src  /app/    /app.module.ts    /app.component.ts    /app.component.html
//app.module.tsimport { NgModule } from '@angular/core';import { BrowserModule } from '@angular/platform-browser';import { FormsModule } from '@angular/forms';import { CommonModule } from '@angular/common';import {components} from './select';import { AppComponent } from './app.component';@NgModule({ imports:   [ BrowserModule, FormsModule,CommonModule ], declarations: [ AppComponent,...components], bootstrap:  [ AppComponent ]})export class AppModule { }
//app.component.tsimport { Component } from '@angular/core';@Component({ selector: 'my-app', templateUrl: './app.component.html', styleUrls: ['./app.component.css']})export class AppComponent { name = 'Angular'; defaultValue: any = 'value5' menus: any[] = []; ngOnInit() {  for (let i = 0; i <= 6; i++) {   this.menus.push({    value: 'value' + i,    label: 'item' + i   })  } }}
//app.component.html<nz-select [(value)]="defaultValue" [isOpen]="false"> <div nzOption *ngFor="let m of menus" [value]="m.value">{{m.label}}</div></nz-select><pre> select value is <b>{{defaultValue|json}}</b></pre>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 盐城市| 西丰县| 会宁县| 吉隆县| 金秀| 嘉祥县| 全南县| 永新县| 革吉县| 博野县| 教育| 建瓯市| 荥阳市| 庆元县| 新余市| 乌拉特中旗| 永川市| 祁东县| 新津县| 嵊泗县| 四川省| 景泰县| 万荣县| 永顺县| 彭山县| 大理市| 广灵县| 普定县| 琼中| 江油市| 奉节县| 宣城市| 东海县| 斗六市| 揭西县| 洪洞县| 古交市| 乐昌市| 惠水县| 重庆市| 日土县|