一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - 解決element-ui里的下拉多選框 el-select 時(shí),默認(rèn)值不可刪除問題

解決element-ui里的下拉多選框 el-select 時(shí),默認(rèn)值不可刪除問題

2021-08-23 17:05一起蹦極某囖 JavaScript

這篇文章主要介紹了解決element-ui里的下拉多選框 el-select 時(shí),默認(rèn)值不可刪除問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

這是一個(gè)項(xiàng)目中常見的需求,el-select 為下拉多選,默認(rèn)值不可刪除,或者指定值不可刪除。

實(shí)現(xiàn)效果:

解決element-ui里的下拉多選框 el-select 時(shí),默認(rèn)值不可刪除問題

el-select 如下源碼中 tag closable 屬性為 el-select 的 disabled 屬性,所有明顯不支持。

解決element-ui里的下拉多選框 el-select 時(shí),默認(rèn)值不可刪除問題

解決思路(從el-select 的角度來考慮,其他組件組合的情況暫不考慮)

想要實(shí)現(xiàn)某些選項(xiàng)是不刪除,1、需要tag 不可刪除,2、options 不可選擇

options 不可選擇很好實(shí)現(xiàn),只需要給一個(gè)disabled屬性。tag 不可刪除才是關(guān)鍵。下面是我?guī)追N解決思路。

1、 watch 進(jìn)行監(jiān)聽,當(dāng)操作不可刪除的選項(xiàng)時(shí),el-select 綁定的值中 將之前刪除的選項(xiàng)重新添加到原來的位置。達(dá)到不可刪除的效果。(這種方法雖然可以實(shí)現(xiàn),但是tag上還是會(huì)有 “x” 會(huì)給用戶一種誤導(dǎo))

2、使用樣式,定位到 tag中,將icon “x” 設(shè)置 display:none; 將關(guān)閉 按鈕隱藏,達(dá)到不可刪除的效果。

3、復(fù)制一份 element-ui 中 el-select 源碼 進(jìn)行少量的修改,給 tag 添加一個(gè) closagle 的屬性。達(dá)到可控的效果。(這種方式增加了開發(fā)維護(hù)成本,當(dāng)項(xiàng)目中 element-ui 升級(jí)版本的時(shí)候,需要重新對(duì)源碼賦值一份進(jìn)行修改)

4、使用 derictive 給 element-ui 中 tag 添加樣式,實(shí)際上是對(duì)思路二的一種實(shí)現(xiàn)。

思路是這么一個(gè)思路,也對(duì)思路1和4進(jìn)行了實(shí)現(xiàn)。但是綜合考慮下,還是針對(duì)思路4做下記錄,感覺有一點(diǎn)點(diǎn)復(fù)用意義。其它的參考價(jià)值不大。代碼如下定義了一個(gè)全局的指令,也可以定義在組件里面。

?
1
2
3
4
5
6
7
8
9
10
11
// index.vue
 
 <el-select v-model="ruleform.ability" multiple placeholder="請(qǐng)選擇">
    <el-option
     v-for="(item, index) in abilityoptions"
     :key="index"
     :label="`${item.abilitynamezh}(${item.abilityid})`"
     :disabled="item.required === 1"
     :value="item.abilityid">
    </el-option>
 </el-select>
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
// main.js
 
vue.directive('defaultselect', {
 componentupdated (el, bindings, vnode) {
  // values v-model 綁定值
  // options 下拉選項(xiàng)
  // prop 對(duì)應(yīng) options 中 的 value 屬性
  // defaultprop 默認(rèn)值判斷屬性
  // defaultvalue 默認(rèn)值判斷值
  const [values, options, prop, defaultprop, defaultvalue] = bindings.value
  // 需要隱藏的標(biāo)簽索引
  const indexs = []
  const tempdata = values.map(a => options.find(op => op[prop] === a))
  tempdata.foreach((a, index) => {
   if (a[defaultprop] === defaultvalue) indexs.push(index)
  })
  const dealstyle = function (tags) {
   tags.foreach((el, index) => {
    if (indexs.includes(index) && ![...el.classlist].includes('select-tag-close-none')) {
     el.classlist.add('none')
    }
   })
  }
  // 設(shè)置樣式 隱藏close icon
  const tags = el.queryselectorall('.el-tag__close')
  if (tags.length === 0) {
   // 初始化tags為空處理
   settimeout(() => {
    const tagtemp = el.queryselectorall('.el-tag__close')
    dealstyle(tagtemp)
   })
  } else {
   dealstyle(tags)
  }
 }
})
?
1
2
// style.css
.none { display: none; }

補(bǔ)充知識(shí):vue+elementui+select 選中多個(gè)值,我要?jiǎng)h除其中的一兩個(gè) 方法如下

我就廢話不多說了,大家還是直接看代碼吧~

?
1
2
3
4
5
6
7
8
9
10
11
12
13
<el-select value-key="modulecode"
      multiple filterable
      allow-create default-first-option
      @remove-tag='removetag'
      v-model="ruleform.module3" placeholder="請(qǐng)選擇權(quán)限分類" style="width: 240px">
 <el-option v-for="item in level3" :value="item" :label="item.modulename" :key="item.modulecode"></el-option>
</el-select>
methods:{
 
removetag(key){
 console.log(key);//獲取option中item
}
}

以上這篇解決element-ui里的下拉多選框 el-select 時(shí),默認(rèn)值不可刪除問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://blog.csdn.net/qq_36356218/article/details/102605332

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 天美传媒影视在线免费观看 | 人人爱天天做夜夜爽88 | 啪啪模拟器 | 色婷婷综合久久久 | 国产伦码精品一区二区三区 | 亚洲AV无码专区国产精品麻豆 | 精品国产一区二区三区久久久蜜臀 | 91影视在线看免费观看 | 欧美人shou交在线播放 | 国产精品久线观看视频 | 美女扒开胸罩露出奶 | 91噜噜噜在线观看 | 亚洲国产精品一在线观看 | 丁香六月色婷婷综合网 | 日韩性公交车上xxhd免费 | 果冻传媒在线播放1 | 特级一级全黄毛片免费 | 日韩精选 | 扒开大腿狠狠挺进视频 | 韩国久久精品 | 欧美视频精品一区二区三区 | 精品久久看 | 欧美2区 | 国产精品成人一区二区1 | 欧美精品v欧洲高清 | 免费看日本 | 短篇艳妇系列 | 久久水蜜桃亚洲AV无码精品偷窥 | 99热精品在线观看 | 99午夜| 黄动漫车车好快的车车a | 惩罚美女妲己的尤老师 | 色综合久久中文字幕 | 十六以下岁女子毛片免费 | 国产一区在线播放 | 亚洲精品视频免费在线观看 | 男人午夜视频在线观看 | 国产第一页无线好源 | 色交视频 | 成人二区 | 操好爽|