Vue中使用 ElementUi 的 el-select 實(shí)現(xiàn)全選功能(思路詳解)
前言:在開發(fā)中,有一個(gè)需求是 選項(xiàng)組件中使用到一個(gè) 全選的功能,特在這記錄下實(shí)現(xiàn)的方法,方便后續(xù)的查閱,以及方便大家查閱借鑒。若是有更好的方法,請(qǐng)大家傳授傳授。
效果圖:
思路:就圍繞是 ‘全選’ 還是 單選展開,用布爾字段 selectAll 來(lái)標(biāo)識(shí),selectAll 默認(rèn)是 false 非全選。
全選分支:只有全選和取消權(quán)限操作。
單選分支:判斷下選擇到數(shù)組長(zhǎng)度 是否 與所有選項(xiàng)長(zhǎng)度一樣,是的話就說(shuō)明是全選。否則就是單選。
直接上簡(jiǎn)單的 demo:
<template> <div> <el-form ref="searchform" label-width="150px"> <el-form-item label="select多選demo:"> <el-select v-model="selectValue" @change="changeSelect" multiple clearable placeholder="請(qǐng)選擇" > <el-option key="selectAll" label="全部" value="selectAll"></el-option> <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value" > </el-option> </el-select> </el-form-item> </el-form> </div> </template> <script> export default { data() { return { options: [ { value: '選項(xiàng)1', label: '黃金糕' }, { value: '選項(xiàng)2', label: '雙皮奶' }, { value: '選項(xiàng)3', label: '蚵仔煎' }, { value: '選項(xiàng)4', label: '龍須面' }, { value: '選項(xiàng)5', label: '北京烤鴨' } ], selectValue: [], selectAll: false // 用于標(biāo)識(shí)是否全選--默認(rèn)不全選 } }, created() { console.log(...this.options) console.log(this.options.filter(p => p.value != 'selectAll')) }, methods: { changeSelect(value) { // selectAll 為true 的時(shí)候,就走全選分支,全選后出現(xiàn)的情況就是取消權(quán)限 if (this.selectAll) { this.selectAll = false if (value.indexOf('selectAll') > -1) { this.selectValue = value.filter(p => p != 'selectAll') } else { this.selectValue = [] } } else { // 是否點(diǎn)擊了‘全選'選項(xiàng) if (value.indexOf('selectAll') > -1) { // 有‘全選'選項(xiàng),則將‘全部'和其他值放置一塊 const optionsValue = [] this.options.forEach(item => { optionsValue.push(item.value) }) this.selectValue = ['selectAll', ...optionsValue] this.selectAll = true } else { // 若是勾選選擇的長(zhǎng)度和提供的選項(xiàng)長(zhǎng)度是一樣的,則是 ‘全選' if (value.length === this.options.length) { const optionsValue = [] this.options.forEach(item => { optionsValue.push(item.value) }) this.selectValue = ['selectAll', ...optionsValue] this.selectAll = true } else { // 都是單選 this.selectValue = value } } } // 真實(shí)的勾選值 const realSelect = this.selectValue.filter(item => item != 'selectAll') console.log('realSelect', realSelect) } } } </script> <style lang="scss" scoped></style>
這次的例子比較簡(jiǎn)單,希望對(duì)您有幫助,謝謝支持。
到此這篇關(guān)于VUE中使用 ElementUi 的 el-select 實(shí)現(xiàn)全選功能的文章就介紹到這了,更多相關(guān)vue ElementUi 全選內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue之elementUi的el-select同時(shí)獲取value和label的三種方式
- vue3?element?plus?table?selection展示數(shù)據(jù),默認(rèn)選中功能方式
- Vue?elementui如何實(shí)現(xiàn)表格selection的默認(rèn)勾選
- vue-treeselect(適配Vue3.2)及Element-plus的TreeSelect組件使用
- vue elementui select標(biāo)簽監(jiān)聽change事件失效問(wèn)題
- vue2結(jié)合element-ui實(shí)現(xiàn)TreeSelect樹選擇功能
- Vue Element如何獲取select選擇框選擇的value和label
相關(guān)文章
使用vue-router切換組件時(shí)使組件不銷毀問(wèn)題
這篇文章主要介紹了使用vue-router切換組件時(shí)使組件不銷毀問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09vue封裝自定義指令之動(dòng)態(tài)顯示title操作(溢出顯示,不溢出不顯示)
這篇文章主要介紹了vue封裝自定義指令之動(dòng)態(tài)顯示title操作(溢出顯示,不溢出不顯示),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11Nuxt.js SSR與權(quán)限驗(yàn)證的實(shí)現(xiàn)
這篇文章主要介紹了Nuxt.js SSR與權(quán)限驗(yàn)證的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11Vue?data中隨意改一個(gè)屬性,視圖都會(huì)更新嗎?
這篇文章主要討論Vue?data中隨意改一個(gè)屬性,視圖都會(huì)更新嗎?下面來(lái)自面試官的問(wèn)題然后做i出的一個(gè)問(wèn)題總結(jié),具有一定的參考價(jià)值,需要的小伙伴可以參考一下2021-12-12詳解Vue項(xiàng)目部署遇到的問(wèn)題及解決方案
這篇文章主要介紹了詳解Vue項(xiàng)目部署遇到的問(wèn)題及解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01uniapp使用webview內(nèi)嵌H5的注意事項(xiàng)詳解
在移動(dòng)應(yīng)用開發(fā)中,uniApp框架提供了一種跨平臺(tái)的解決方案,允許開發(fā)者使用一套代碼來(lái)構(gòu)建iOS、Android等多平臺(tái)的應(yīng)用,這篇文章主要給大家介紹了關(guān)于uniapp使用webview內(nèi)嵌H5的注意事項(xiàng),需要的朋友可以參考下2024-07-07