vue+elementui可多選的el-select下拉框的互斥問題

下拉框互斥付燥,即:同時有多個下拉框敷钾,可選內(nèi)容option是相同的枝哄,有一個下拉框選了某項,其他下拉框?qū)⒉荒茉龠M行選擇阻荒。

1.首先需要4個el-select下拉框挠锥,注意有multiple屬性,該文章只適用于帶有multiple屬性的下拉框侨赡,如果需要單選下拉框互斥蓖租,請移步我的主頁看(vue+elementui單選el-select下拉框的互斥問題)。
   <el-form label-width="80px">
      <el-form-item label="愛好1">
        <el-select v-model="hobby.hobby1" @remove-tag="removeSelect" @change="changeSelect" multiple>
          <el-option
          v-for="(item,index) in hobbyList"
          :key="index"
          :label="item.value"
          :value="item.value"
          :disabled="item.disabled"
          ></el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="愛好2">
        <el-select v-model="hobby.hobby2" @remove-tag="removeSelect" @change="changeSelect" multiple>
          <el-option
          v-for="(item,index) in hobbyList"
          :key="index"
          :label="item.value"
          :value="item.value"
          :disabled="item.disabled"
          ></el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="愛好3">
        <el-select v-model="hobby.hobby3" @remove-tag="removeSelect" @change="changeSelect" multiple>
          <el-option
          v-for="(item,index) in hobbyList"
          :key="index"
          :label="item.value"
          :value="item.value"
          :disabled="item.disabled"
          ></el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="愛好4">
        <el-select v-model="hobby.hobby4" @remove-tag="removeSelect" @change="changeSelect" multiple>
          <el-option
          v-for="(item,index) in hobbyList"
          :key="index"
          :label="item.value"
          :value="item.value"
          :disabled="item.disabled"
          ></el-option>
        </el-select>
      </el-form-item>
    </el-form>
2.給下拉框綁定數(shù)據(jù)羊壹,有4個下拉框蓖宦,所以要綁定4個值,放到一個hobby對象中油猫,可以看的更加清楚明了稠茂。
      changeArr: [],//存放選中選項的數(shù)組
      hobby: {//el-select綁定的值
        hobby1: '',
        hobby2: '',
        hobby3: '',
        hobby4: ''
      },
      hobbyList: [//下拉框遍歷option
        {value: '001', disabled: false},
        {value: '002', disabled: false},
        {value: '003', disabled: false},
        {value: '004', disabled: false},
        {value: '005', disabled: false},
        {value: '006', disabled: false}
      ]
3.編寫方法,一共需要兩個方法情妖,change方法睬关,選中某個選項時觸發(fā),remove-tag方法毡证,移除某個選項時觸發(fā)电爹。
    //change方法
    changeSelect () {
      //對hobby對象進行遍歷,把選中的值放到changeArr數(shù)組中
      for (var key in this.hobby) {
        this.hobby[key].forEach(item => {
          this.changeArr.push(item)
        })
      }
      //有可能會出現(xiàn)重復的元素料睛,所以對changeArr數(shù)組進行去重操作
      this.changeArr = this.quchong(this.changeArr)
      //對changeArr進行遍歷丐箩,對hobbyList進行遍歷,
      //changeArr有哪一項秦效,就把hobbyList中該項的disabled屬性置為true雏蛮,禁用
      this.changeArr.forEach(item => {
        this.hobbyList.forEach(yitem => {
          if (item === yitem.value) {
            yitem.disabled = true
          }
        })
      })
    },
    //remove-tag方法,移除某一項時觸發(fā)該方法
    removeSelect (val) {
      //將移除的那一項阱州,從changeArr數(shù)組中找到下標挑秉,并移除
      var str = this.changeArr.findIndex(item => item === val)
      this.changeArr.splice(str, 1)
      //對hobbyList數(shù)組遍歷,將移除的那項disabled屬性置為false苔货,啟用
      this.hobbyList.forEach((item) => {
        if (val === item.value) {
          item.disabled = false
        }
      })
    },
    //數(shù)組去重的方法犀概,避免changeArr出現(xiàn)重復的元素
    quchong (arr) {
      return arr.filter(function (item, index, arr) {
        return arr.indexOf(item, 0) === index
      })
    }
到此為止,如圖所示夜惭,可多選的el-selsct下拉框的互斥問題就已經(jīng)解決姻灶。
image.png
實際工作中,有很多類似的場景诈茧,該文章中講述的是4個可多選的el-select下拉框(帶有multiple屬性)互斥的問題产喉,如果需要的下拉框數(shù)量不同,大家可酌情修改。
如果需要單選下拉框互斥曾沈,請移步我的主頁看(vue+elementui單選el-select下拉框的互斥問題)这嚣,謝謝觀看!H恪姐帚!
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市障涯,隨后出現(xiàn)的幾起案子罐旗,更是在濱河造成了極大的恐慌,老刑警劉巖唯蝶,帶你破解...
    沈念sama閱讀 218,036評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件九秀,死亡現(xiàn)場離奇詭異,居然都是意外死亡生棍,警方通過查閱死者的電腦和手機颤霎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來涂滴,“玉大人友酱,你說我怎么就攤上這事∪嶙荩” “怎么了缔杉?”我有些...
    開封第一講書人閱讀 164,411評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長搁料。 經(jīng)常有香客問我或详,道長,這世上最難降的妖魔是什么郭计? 我笑而不...
    開封第一講書人閱讀 58,622評論 1 293
  • 正文 為了忘掉前任霸琴,我火速辦了婚禮,結果婚禮上昭伸,老公的妹妹穿的比我還像新娘梧乘。我一直安慰自己,他們只是感情好庐杨,可當我...
    茶點故事閱讀 67,661評論 6 392
  • 文/花漫 我一把揭開白布选调。 她就那樣靜靜地躺著,像睡著了一般灵份。 火紅的嫁衣襯著肌膚如雪仁堪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,521評論 1 304
  • 那天填渠,我揣著相機與錄音弦聂,去河邊找鬼鸟辅。 笑死,一個胖子當著我的面吹牛横浑,可吹牛的內(nèi)容都是我干的剔桨。 我是一名探鬼主播,決...
    沈念sama閱讀 40,288評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼徙融,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了瑰谜?” 一聲冷哼從身側響起欺冀,我...
    開封第一講書人閱讀 39,200評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎萨脑,沒想到半個月后隐轩,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,644評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡渤早,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,837評論 3 336
  • 正文 我和宋清朗相戀三年职车,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鹊杖。...
    茶點故事閱讀 39,953評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡悴灵,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出骂蓖,到底是詐尸還是另有隱情积瞒,我是刑警寧澤,帶...
    沈念sama閱讀 35,673評論 5 346
  • 正文 年R本政府宣布登下,位于F島的核電站茫孔,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏被芳。R本人自食惡果不足惜缰贝,卻給世界環(huán)境...
    茶點故事閱讀 41,281評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望畔濒。 院中可真熱鬧剩晴,春花似錦、人聲如沸篓冲。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽壹将。三九已至嗤攻,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間诽俯,已是汗流浹背妇菱。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評論 1 269
  • 我被黑心中介騙來泰國打工承粤, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人闯团。 一個月前我還...
    沈念sama閱讀 48,119評論 3 370
  • 正文 我出身青樓辛臊,卻偏偏與公主長得像,于是被迫代替她去往敵國和親房交。 傳聞我的和親對象是個殘疾皇子彻舰,可洞房花燭夜當晚...
    茶點故事閱讀 44,901評論 2 355

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