亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue中使用 ElementUi 的 el-select 實(shí)現(xiàn)全選功能(思路詳解)

 更新時(shí)間:2024年02月06日 11:35:55   作者:小熊貓Yzt_199626  
在開發(fā)中,有一個(gè)需求是 選項(xiàng)組件中使用到一個(gè) 全選的功能,特在這記錄下實(shí)現(xiàn)的方法,方便后續(xù)的查閱,以及方便大家查閱借鑒,對(duì)vue   ElementUi 全選功能感興趣的朋友一起看看吧

前言:在開發(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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用vue-router切換組件時(shí)使組件不銷毀問(wèn)題

    使用vue-router切換組件時(shí)使組件不銷毀問(wèn)題

    這篇文章主要介紹了使用vue-router切換組件時(shí)使組件不銷毀問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue封裝自定義指令之動(dòng)態(tài)顯示title操作(溢出顯示,不溢出不顯示)

    vue封裝自定義指令之動(dòng)態(tài)顯示title操作(溢出顯示,不溢出不顯示)

    這篇文章主要介紹了vue封裝自定義指令之動(dòng)態(tài)顯示title操作(溢出顯示,不溢出不顯示),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-11-11
  • 在原生HTML中使用VUE的保姆級(jí)教學(xué)

    在原生HTML中使用VUE的保姆級(jí)教學(xué)

    Vue.js是一種流行的JavaScript框架,用于構(gòu)建交互式的Web應(yīng)用程序,這篇文章主要給大家介紹了關(guān)于在原生HTML中使用VUE的保姆級(jí)教學(xué),需要的朋友可以參考下
    2023-10-10
  • Vue列表頁(yè)渲染優(yōu)化詳解

    Vue列表頁(yè)渲染優(yōu)化詳解

    這篇文章主要為大家詳細(xì)介紹了Vue列表頁(yè)渲染優(yōu)化的操作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • Nuxt.js SSR與權(quán)限驗(yàn)證的實(shí)現(xiàn)

    Nuxt.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-11
  • Vue?data中隨意改一個(gè)屬性,視圖都會(huì)更新嗎?

    Vue?data中隨意改一個(gè)屬性,視圖都會(huì)更新嗎?

    這篇文章主要討論Vue?data中隨意改一個(gè)屬性,視圖都會(huì)更新嗎?下面來(lái)自面試官的問(wèn)題然后做i出的一個(gè)問(wèn)題總結(jié),具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2021-12-12
  • vue3中?provide?和?inject?用法及原理

    vue3中?provide?和?inject?用法及原理

    這篇文章主要介紹vue3中?provide?和?inject?用法及原理,provide?和?inject可以?解決多次組件傳遞數(shù)據(jù)的問(wèn)題,下面文章是具體的用法和實(shí)現(xiàn)原理,具有一定的參考價(jià)值,需要的朋友可以參考一下,希望對(duì)大家有所幫助
    2021-11-11
  • Vue2中easyplayer的使用教程詳解

    Vue2中easyplayer的使用教程詳解

    EasyPlayer.js是集播放http-flv,?hls,?websocket?于一身的H5視頻直播/視頻點(diǎn)播播放器,?使用簡(jiǎn)單,?功能強(qiáng)大,下面大家就跟隨小編一起學(xué)習(xí)一下它的具體使用吧
    2023-08-08
  • 詳解Vue項(xiàng)目部署遇到的問(wèn)題及解決方案

    詳解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-01
  • uniapp使用webview內(nèi)嵌H5的注意事項(xiàng)詳解

    uniapp使用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

最新評(píng)論