ng-alain的sf如何自定義部件

一、背景

最近使用ng-alain做前端源内,sf的部件很豐富葡粒,但是做起來之后就會發(fā)現(xiàn),多多少少會有一些不符合需求的東西膜钓,比如:


file

這是一個(gè)string的部件嗽交,后邊跟上一個(gè)單位看著很不錯,但是我們通常在使用number時(shí)會更需要這個(gè)單位颂斜,然而官方的部件并沒有
再比如:


file

我想做一個(gè)編輯框夫壁,要求內(nèi)容不可編輯,并且該內(nèi)容要從別的列表進(jìn)行選擇沃疮,下拉選擇可以滿足需求盒让,但是如果內(nèi)容太多,有時(shí)就不方便使用下拉框了忿磅,那么這時(shí)候我們就需要自定義

二糯彬、自定義ng-alain部件的流程

1、組件的整體結(jié)構(gòu)

file

2葱她、首先撩扒,組件click-input.component.html,自定義組件要包在sf-item-wrap特殊標(biāo)簽里面

<sf-item-wrap [id]="id" [schema]="schema" [ui]="ui" [showError]="showError" [error]="error" [showTitle]="schema.title">
  <!-- 開始自定義控件區(qū)域 -->
  <div nz-row>
    <div nz-col nzSpan="16"><input type="text" [placeholder]="placeholder" nz-input [(ngModel)]="content" [disabled]="inputDisable" (ngModelChange)="onChange()"></div>
    <div nz-col nzSpan="2" nzPush="2"></div>
    <div nz-col nzSpan="6"><button nz-button type="button" nzType="primary" (click)="test()" >{{btnTitle}}</button></div>
  </div>
  <!-- 結(jié)束自定義控件區(qū)域 -->
</sf-item-wrap>

3吨些、寫組件click-input.component搓谆,繼承ControlWidget

import {Component, OnInit} from '@angular/core';
import { ControlWidget } from '@delon/form';

@Component({
  selector: 'app-product-widget-click-input',
  templateUrl: './click-input.component.html',
})
export class ClickInputComponent extends ControlWidget implements OnInit {

  /* 用于注冊小部件 KEY 值 */
  static readonly KEY = 'click-input';

  // 價(jià)格區(qū)間
  content: any;
  // to: any;

  placeholder: string;   // 使用的時(shí)候用來綁定  ui: {placeholder: '請選擇業(yè)務(wù)系統(tǒng)' } 
  inputDisable: boolean; // 使用的時(shí)候用來綁定 ui: {inputDisable: true,   // input是否可用}
  btnTitle: string;  // 使用的時(shí)候用來綁定 ui: {btnTitle: '選擇數(shù)據(jù)',}   按鈕名稱

  ngOnInit(): void {
    this.placeholder = this.ui.placeholder || '請輸入';  // 使用的時(shí)候用來綁定  ui: {placeholder: '請選擇業(yè)務(wù)系統(tǒng)' } 
    this.inputDisable = this.ui.inputDisable || false;  // 使用的時(shí)候用來綁定 ui: {inputDisable: true,   // input是否可用}
    this.btnTitle = this.ui.btnTitle || '按鈕';  // 使用的時(shí)候用來綁定 ui: {btnTitle: '選擇數(shù)據(jù)',}
  }

  getData = () => {
    return this.content;
  }

  onChange() {
    const v = this.getData();
    this.setValue(v);
  }

  // reset 可以更好的解決表單重置過程中所需要的新數(shù)據(jù)問題
  reset(value: any) {
    if (value) {
      console.log(value);
      const content = value;
      this.content = content;
      // this.to = to;
      this.setValue(value);
    }

  }

  test(value?: string){
    if (this.ui.click) {
      this.ui.click(value);   // 可以在組件里直接調(diào)用使用ui的配置那里的方法  ui: {click: (value) => this.test(value),}
    }
  }

}

4、在shared.module.ts中注冊部件

涉及到項(xiàng)目內(nèi)容豪墅,以下只展示注冊部件的住要內(nèi)容


// 自定義 小部件
const WIDGETS = [
  RangeInputComponent,
  ClickInputComponent
];

@NgModule({
  declarations: [
    // your components
    ...COMPONENTS,
    ...DIRECTIVES,
    ...WIDGETS
  ],
})

export class SharedModule {
  constructor(widgetRegistry: WidgetRegistry) {
    // 注冊 自定義的 widget
    for (const widget of WIDGETS){
      widgetRegistry.register(widget.KEY /* 'range-input' */, widget);
    }
  }
}

5泉手、使用自定義部件

file

channel-select.component.html

<sf [schema]="schema" (formSubmit)="submit($event)"></sf>

channel-select.component.ts

schema: SFSchema = {
   properties: {
     btn: { type: 'string', title: '編輯框+按鈕',
       default: '1234', // 設(shè)默認(rèn)值
       ui: {
         widget: 'click-input',
         placeholder: '請選擇業(yè)務(wù)系統(tǒng)',
         // inputDisable: true,   // input是否可用
         btnTitle: '選擇數(shù)據(jù)',
         click: (value) => this.test(value),
       }
     },
   }
 };

個(gè)人博客 蝸牛

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市偶器,隨后出現(xiàn)的幾起案子斩萌,更是在濱河造成了極大的恐慌缝裤,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,539評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件颊郎,死亡現(xiàn)場離奇詭異憋飞,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)姆吭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,594評論 3 396
  • 文/潘曉璐 我一進(jìn)店門榛做,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人内狸,你說我怎么就攤上這事检眯。” “怎么了昆淡?”我有些...
    開封第一講書人閱讀 165,871評論 0 356
  • 文/不壞的土叔 我叫張陵锰瘸,是天一觀的道長。 經(jīng)常有香客問我瘪撇,道長获茬,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,963評論 1 295
  • 正文 為了忘掉前任倔既,我火速辦了婚禮,結(jié)果婚禮上鹏氧,老公的妹妹穿的比我還像新娘渤涌。我一直安慰自己,他們只是感情好把还,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,984評論 6 393
  • 文/花漫 我一把揭開白布实蓬。 她就那樣靜靜地躺著,像睡著了一般吊履。 火紅的嫁衣襯著肌膚如雪安皱。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,763評論 1 307
  • 那天艇炎,我揣著相機(jī)與錄音酌伊,去河邊找鬼。 笑死缀踪,一個(gè)胖子當(dāng)著我的面吹牛居砖,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播驴娃,決...
    沈念sama閱讀 40,468評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼奏候,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了唇敞?” 一聲冷哼從身側(cè)響起蔗草,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤咒彤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后咒精,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蔼紧,經(jīng)...
    沈念sama閱讀 45,850評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,002評論 3 338
  • 正文 我和宋清朗相戀三年狠轻,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了奸例。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,144評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡向楼,死狀恐怖查吊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情湖蜕,我是刑警寧澤逻卖,帶...
    沈念sama閱讀 35,823評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站昭抒,受9級特大地震影響评也,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜灭返,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,483評論 3 331
  • 文/蒙蒙 一盗迟、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧熙含,春花似錦罚缕、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,026評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蚓聘,卻和暖如春腌乡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背夜牡。 一陣腳步聲響...
    開封第一講書人閱讀 33,150評論 1 272
  • 我被黑心中介騙來泰國打工与纽, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人氯材。 一個(gè)月前我還...
    沈念sama閱讀 48,415評論 3 373
  • 正文 我出身青樓渣锦,卻偏偏與公主長得像,于是被迫代替她去往敵國和親氢哮。 傳聞我的和親對象是個(gè)殘疾皇子袋毙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,092評論 2 355