Switch開關(guān)控制禁用啟用單選按鈕組和下拉框

1. 功能實現(xiàn)

繼上一篇ElementUI單選按鈕控制下拉框赴捞,添加一個switch開關(guān)組件笨忌,當(dāng)切換到禁用狀態(tài)频丘,單選按鈕組和下拉框都不能編輯办成;當(dāng)切換到啟用狀態(tài),單選按鈕組和下拉框可以進行選擇和切換搂漠。

2. 使用技術(shù)

  • vue.js
  • vue-router
  • element
  • webpack

3. 實現(xiàn)源碼

<template>
  <el-row :gutter="20">
    <el-col :span="5">
      <el-form ref="dataForm" :model="dataForm">
        <el-form-item label="禁用/啟用">
          <el-switch v-model="dataForm.isDisabled"
                     active-color="#00FF00"
                     inactive-color="#ccc"
                     active-value="1"
                     inactive-value="0"
                     active-text="啟用"
                     inactive-text="禁用"
                     @change="changeDisabled"></el-switch>
        </el-form-item>
        <el-form-item label="類型" prop="type">
          <el-radio-group ref="radios" v-model="dataForm.type" @change="changeType" :disabled="dataForm.disabled">
            <el-radio :label="1">A</el-radio>
            <el-radio :label="2">B</el-radio>
            <el-radio :label="3">C</el-radio>
            <el-radio :label="4">D</el-radio>
          </el-radio-group>
        </el-form-item>
        <el-form-item label="名稱">
          <el-select v-model="dataForm.username" :disabled="dataForm.disabled">
            <el-option v-for="item in dataForm.options" :key="item.value" :label="item.label" :value="parseInt(item.value)"></el-option>
          </el-select>
        </el-form-item>
      </el-form>
    </el-col>
  </el-row>
</template>

<script>
  export default {
    name: 'Sa',
    data() {
      return {
        dataForm: {
          type: 1,
          username: '',
          isDisabled: false,
          disabled: true,
          options: [],
          option: [{
            label: 'AAA',
            value: '2019001',
            type: 'A'
          }, {
            label: 'AAB',
            value: '2019002',
            type: 'A'
          }, {
            label: 'AAC',
            value: '2019003',
            type: 'A'
          }, {
            label: 'AAD',
            value: '2019004',
            type: 'A'
          }, {
            label: 'BBA',
            value: '2019005',
            type: 'B'
          }, {
            label: 'BBB',
            value: '2019006',
            type: 'B'
          }, {
            label: 'BBC',
            value: '2019007',
            type: 'B'
          }, {
            label: 'BBD',
            value: '2019008',
            type: 'B'
          }, {
            label: 'CCA',
            value: '2019009',
            type: 'C'
          }, {
            label: 'CCB',
            value: '2019010',
            type: 'C'
          }, {
            label: 'CCC',
            value: '2019011',
            type: 'C'
          }, {
            label: 'CCD',
            value: '2019012',
            type: 'C'
          }, {
            label: 'DDA',
            value: '2019013',
            type: 'D'
          }, {
            label: 'DDB',
            value: '2019014',
            type: 'D'
          }, {
            label: 'DDC',
            value: '2019015',
            type: 'D'
          }, {
            label: 'DDD',
            value: '2019016',
            type: 'D'
          }]
        }
      }
    },
    mounted() {
      this.filterData('A')
    },
    methods: {
      changeType(val) {
        this.dataForm.username = ''
        var txt = this.$refs.radios.$children[val - 1].$el.innerText
        console.log(txt)
        this.filterData(txt)
      },
      filterData(params) {
        let options = this.dataForm.option
        let res = []
        for (let i = 0; i < options.length; i++) {
          if (params == options[i].type) {
            res.push(options[i])
          }
        }

        this.dataForm.options = res
      },
      changeDisabled(val){
        if(val == 1) {
          this.dataForm.disabled = false
        } else {
          this.dataForm.disabled = true
        }
        console.log(val)
      }
    }
  }
</script>

<style>
</style>

4. 源碼分析

4.1 el-switch組件屬性說明

(1)active-color:switch 打開時的背景色
(2)inactive-color:switch 關(guān)閉時的背景色
(3)active-value:switch 打開時的值
(4)inactive-value:switch 關(guān)閉時的值
(5)active-text:switch 打開時的文字描述
(6)inactive-text:switch 關(guān)閉時的文字描述

4.2 el-switch組件事件說明

el-switch組件有change事件迂卢,跟el-radio、el-checkbox和el-select組件的change事件一樣桐汤,傳入一個val(改變之后的值)

4.3 開關(guān)組件控制單選按鈕組和下拉框

通過在單選按鈕組和下拉框上綁定一個disabled而克,如果開關(guān)的值為1,設(shè)置disabled為false怔毛,否則為true员萍,以這樣的方式控制單選按鈕組和下拉框

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市拣度,隨后出現(xiàn)的幾起案子碎绎,更是在濱河造成了極大的恐慌蜂莉,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,311評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件混卵,死亡現(xiàn)場離奇詭異,居然都是意外死亡窖张,警方通過查閱死者的電腦和手機幕随,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來宿接,“玉大人赘淮,你說我怎么就攤上這事∧丽” “怎么了梢卸?”我有些...
    開封第一講書人閱讀 152,671評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長副女。 經(jīng)常有香客問我蛤高,道長,這世上最難降的妖魔是什么碑幅? 我笑而不...
    開封第一講書人閱讀 55,252評論 1 279
  • 正文 為了忘掉前任戴陡,我火速辦了婚禮,結(jié)果婚禮上沟涨,老公的妹妹穿的比我還像新娘恤批。我一直安慰自己,他們只是感情好裹赴,可當(dāng)我...
    茶點故事閱讀 64,253評論 5 371
  • 文/花漫 我一把揭開白布喜庞。 她就那樣靜靜地躺著,像睡著了一般棋返。 火紅的嫁衣襯著肌膚如雪延都。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,031評論 1 285
  • 那天懊昨,我揣著相機與錄音窄潭,去河邊找鬼。 笑死酵颁,一個胖子當(dāng)著我的面吹牛嫉你,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播躏惋,決...
    沈念sama閱讀 38,340評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼幽污,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了簿姨?” 一聲冷哼從身側(cè)響起距误,我...
    開封第一講書人閱讀 36,973評論 0 259
  • 序言:老撾萬榮一對情侶失蹤簸搞,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后准潭,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體趁俊,經(jīng)...
    沈念sama閱讀 43,466評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,937評論 2 323
  • 正文 我和宋清朗相戀三年刑然,在試婚紗的時候發(fā)現(xiàn)自己被綠了寺擂。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,039評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡泼掠,死狀恐怖怔软,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情择镇,我是刑警寧澤挡逼,帶...
    沈念sama閱讀 33,701評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站腻豌,受9級特大地震影響家坎,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜吝梅,卻給世界環(huán)境...
    茶點故事閱讀 39,254評論 3 307
  • 文/蒙蒙 一乘盖、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧憔涉,春花似錦订框、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至国旷,卻和暖如春矛物,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背跪但。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工履羞, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人屡久。 一個月前我還...
    沈念sama閱讀 45,497評論 2 354
  • 正文 我出身青樓忆首,卻偏偏與公主長得像,于是被迫代替她去往敵國和親被环。 傳聞我的和親對象是個殘疾皇子糙及,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,786評論 2 345