最簡(jiǎn)單的Angular 雙向綁定

使用:

<app-radio-group class="xs-edition"
    [labels]="['個(gè)人版', '企業(yè)版']"
    [values]="[0, 1]"
    [name]="'license'"
    [(ngModel)]="item.productLicense"
></app-radio-group>

TS

import {Component, forwardRef, Input, OnInit} from '@angular/core'
import {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms'
import {RadioGroupItem} from './radio-group-item'

const CUSTOM_VALUE_ACCESSOR = {
  provide: NG_VALUE_ACCESSOR,
  useExisting: forwardRef(() => RadioGroupComponent),
  multi: true
}

@Component({
  selector: 'app-radio-group',
  templateUrl: './radio-group.component.html',
  styleUrls: ['./radio-group.component.scss'],
  providers: [CUSTOM_VALUE_ACCESSOR]
})
export class RadioGroupComponent implements OnInit, ControlValueAccessor {

  private _value: RadioGroupItem = new RadioGroupItem()

  @Input() values = []

  @Input() labels = []

  @Input() name = 'radioGroup'

  onChange = (_) => {
  }

  onTouched = () => {
  }

  writeValue(obj: any): void {
    if (this._value !== obj) {
      this._value = obj
    }
  }

  registerOnChange(fn: any): void {
    this.onChange = fn
  }

  registerOnTouched(fn: any): void {
    this.onTouched = fn
  }

  constructor() {
  }

  ngOnInit() {
  }

}

HTML

<ul>
  <li *ngFor="let item of values; let i = index">
    <input type="radio" [value]="item" [name]="name" [id]="name + '_' + i" [ngModel]="_value" (ngModelChange)="_value = $event; onChange($event)">
    <label [for]="name + '_' + i" [class.checked]="_value === item">{{ labels[i] || '' }}</label>
  </li>
</ul>

CSS/SCSS

ul {

  display: flex;

  li {
    flex-grow: 1;

    input[type=radio] {
      display: none;
    }

    label {
      display: block;
      margin: 0;
      text-align: center;
      padding: 1em 0;
      border: 1px solid #eeeeee;

      &.checked {
        border: 1px solid #127cc3;
      }
    }
  }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末熙暴,一起剝皮案震驚了整個(gè)濱河市珍逸,隨后出現(xiàn)的幾起案子语泽,更是在濱河造成了極大的恐慌榕堰,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,464評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件贞谓,死亡現(xiàn)場(chǎng)離奇詭異铲汪,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)膏潮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,033評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門锻狗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人焕参,你說(shuō)我怎么就攤上這事轻纪。” “怎么了叠纷?”我有些...
    開(kāi)封第一講書人閱讀 169,078評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵刻帚,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我涩嚣,道長(zhǎng)崇众,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 59,979評(píng)論 1 299
  • 正文 為了忘掉前任航厚,我火速辦了婚禮顷歌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘幔睬。我一直安慰自己眯漩,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,001評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布麻顶。 她就那樣靜靜地躺著赦抖,像睡著了一般舱卡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上队萤,一...
    開(kāi)封第一講書人閱讀 52,584評(píng)論 1 312
  • 那天灼狰,我揣著相機(jī)與錄音,去河邊找鬼浮禾。 笑死交胚,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的盈电。 我是一名探鬼主播蝴簇,決...
    沈念sama閱讀 41,085評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼匆帚!你這毒婦竟也來(lái)了熬词?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 40,023評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤吸重,失蹤者是張志新(化名)和其女友劉穎互拾,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體嚎幸,經(jīng)...
    沈念sama閱讀 46,555評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡颜矿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,626評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了嫉晶。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片骑疆。...
    茶點(diǎn)故事閱讀 40,769評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖替废,靈堂內(nèi)的尸體忽然破棺而出箍铭,到底是詐尸還是另有隱情,我是刑警寧澤椎镣,帶...
    沈念sama閱讀 36,439評(píng)論 5 351
  • 正文 年R本政府宣布诈火,位于F島的核電站,受9級(jí)特大地震影響状答,放射性物質(zhì)發(fā)生泄漏冷守。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,115評(píng)論 3 335
  • 文/蒙蒙 一剪况、第九天 我趴在偏房一處隱蔽的房頂上張望教沾。 院中可真熱鬧,春花似錦译断、人聲如沸授翻。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,601評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)堪唐。三九已至巡语,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間淮菠,已是汗流浹背男公。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,702評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留合陵,地道東北人枢赔。 一個(gè)月前我還...
    沈念sama閱讀 49,191評(píng)論 3 378
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像拥知,于是被迫代替她去往敵國(guó)和親踏拜。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,781評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容