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

Element UI框架中巧用樹選擇器的實(shí)現(xiàn)

 更新時(shí)間:2018年12月12日 16:38:00   作者:程序媛兔子  
這篇文章主要介紹了Element UI框架中巧用樹選擇器的實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

本文介紹了Element UI框架中巧用樹選擇器的實(shí)現(xiàn),分享給大家,順便給自己留個(gè)筆記,具體如下:

介紹

在Element UI框架中有選擇器和樹形控件,但是沒有樹形選擇器,也就是圖上的這種方式的選擇器,所以只能自定義選擇器的slot。這里介紹的是多選情況,如果是單選則去掉復(fù)選框,修改一部分的處理即可。

html部分的代碼:

<el-select
  v-model="dataArr"
  :multiple="multiple"
  filterable
  :placeholder="placeholder"
  :disabled="disabled"
  :collapse-tags="multiple"
  @remove-tag="handleTagChange"
  @visible-change="handleOptionHidden"
  class="hi-input">
  <el-option value="0"
    class="hidden">
  </el-option>
  <!--el-tree綁定的數(shù)組中children里的key值不能是0-->
  <el-tree
    ref="tree"
    :data="options"
    node-key="key"
    show-checkbox
    :default-checked-keys="selectedData"
    @check="handleCheckChange"
    :props="defaultProps">
  </el-tree>
</el-select>

在el-tree中綁定的值是已選擇的key值組成的數(shù)組,check綁定的事件函數(shù)是為了:

  • 得到現(xiàn)在樹選擇器上選中的值
  • 過濾undefined、null的值(是為了容錯(cuò)處理) 具體代碼如下:
handleCheckChange: function() {
  this.selectedData = this.$refs.tree.getCheckedKeys().filter(_ => _);
}

因?yàn)檫x擇器是有l(wèi)abel值和key值區(qū)分的,所以,每當(dāng)在el-tree中選中值key值變化時(shí),選擇器上綁定的值label值也應(yīng)該隨之變化,所以在watch中監(jiān)聽key值,目的是在el-tree綁定的data中找到當(dāng)前key值對應(yīng)的label值 具體代碼如下:

watch: {
  selectedData: function(newValue) {
    this.$nextTick(() => { this.dataArr = this.handleDataTransform(newValue, 'key', 'label'); });
  },
},
methods: {
  getNameById(array, value, id, name, multi) {
    let arr = array || [];
    let flag;
    let result = arr.filter(item => {
      return item[id] + '' === value + '';
    });
    if (multi) {
      flag = result.map(item => {
        return item[name];
      });
    } else {
      let obj = result[0];
      flag = name ? obj && obj[name] : obj;
    }
    return flag;
  },
  handleDataTransform: function(source, key, value) {
    return this.options.map(_ => {
      let arr = source.map(item => this.$util.getNameById(
        _.children,
        item,
        key,
        value
      )).filter(item => item);
      return arr;
    }).reduce((acc, cur) => {
      return acc.concat(cur);
    }, []);
  }
}

到這里為止,已經(jīng)完成了樹形控件到選擇器的單向綁定,現(xiàn)在處理選擇器的值發(fā)生改變時(shí),樹形控件也變化。因?yàn)榇藭r(shí)是多選,所以要在remove-tag事件中處理,具體代碼如下:

handleTagChange: function() {
  // handleDataTransform已經(jīng)在之前定義過
  this.selectedData = this.handleDataTransform(this.dataArr, 'label', 'key');
  this.$refs.tree.setCheckedKeys(this.selectedData);
},

此時(shí),這個(gè)樹形選擇器已經(jīng)完成了~:clap::clap:,但是,我們還可以進(jìn)一步優(yōu)化,比如:如果選擇后的內(nèi)容與選擇前的內(nèi)容一樣,不再發(fā)生請求的處理。 在選擇器中綁定的visible-change事件可以處理,思想是:

  • item值為true,即展開下拉框時(shí),把此時(shí)的值存儲下來,注意:warning::這時(shí)候存儲下來的值必須放在一個(gè)全局變量中,函數(shù)內(nèi)的變量會在每次進(jìn)入這個(gè)函數(shù)時(shí)初始化,所以在下拉框收起再進(jìn)來這個(gè)函數(shù)時(shí),之前存儲的值已經(jīng)沒有了。
  • item值為false,即收起下拉框時(shí),判斷之前存儲下的變量值和當(dāng)前變量值是否相等,如果不相等才觸發(fā)數(shù)據(jù)的更新。 具體代碼如下:
handleOptionHidden: function(item) {
  // 處理選中內(nèi)容沒變的情況
  if (item) {
    this.selectedItem = [...this.selectedData];
  } else {
    // this.$util.isEqual()是判斷兩個(gè)數(shù)組是否相等函數(shù),網(wǎng)上很多,請自行谷歌
    if (!this.$util.isEqual(this.selectedItem, this.selectedData)) {
      this.handleUpdate(this.selectedData);
    }
  }
    },

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue.js實(shí)現(xiàn)照片放大功能

    vue.js實(shí)現(xiàn)照片放大功能

    這篇文章主要為大家詳細(xì)介紹了vue.js實(shí)現(xiàn)照片放大功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • 查看當(dāng)前vue項(xiàng)目所需Node.js版本的方法

    查看當(dāng)前vue項(xiàng)目所需Node.js版本的方法

    這篇文章主要大家介紹了查看當(dāng)前vue項(xiàng)目所需Node.js版本的方法,文章通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2023-11-11
  • 詳解vue項(xiàng)目優(yōu)化之按需加載組件-使用webpack require.ensure

    詳解vue項(xiàng)目優(yōu)化之按需加載組件-使用webpack require.ensure

    本篇文章主要介紹了詳解vue項(xiàng)目優(yōu)化之按需加載組件-使用webpack require.ensure,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Vue引入并使用Element組件庫的兩種方式小結(jié)

    Vue引入并使用Element組件庫的兩種方式小結(jié)

    本文主要介紹了Vue引入并使用Element組件庫的兩種方式小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • 利用Vue.js框架實(shí)現(xiàn)火車票查詢系統(tǒng)(附源碼)

    利用Vue.js框架實(shí)現(xiàn)火車票查詢系統(tǒng)(附源碼)

    這篇文章主要介紹了利用Vue.js框架實(shí)現(xiàn)火車票查詢系統(tǒng)的相關(guān)資料,,文中給出了詳細(xì)的介紹與示例代碼,并在文章結(jié)尾給出了完整的項(xiàng)目下載,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • 打包組件報(bào)錯(cuò):Error:Cannot?find?module?'vue/compiler-sfc'

    打包組件報(bào)錯(cuò):Error:Cannot?find?module?'vue/compiler-sfc&ap

    最近遇到這樣的問題,vue組件庫搭建過程中使用webpack打包組件時(shí)報(bào)錯(cuò),本文給大家分享打包組件報(bào)錯(cuò):Error:?Cannot?find?module?‘vue/compiler-sfc‘的解決方法,感興趣的朋友一起看看吧
    2023-12-12
  • element-ui中樣式覆蓋問題的方法總結(jié)

    element-ui中樣式覆蓋問題的方法總結(jié)

    我們在使用element-ui的時(shí)候經(jīng)常會遇到需要修改組件默認(rèn)樣式,下面這篇文章主要給大家介紹了關(guān)于element-ui中樣式覆蓋問題的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-03-03
  • vue子組件通過.sync修飾符修改props屬性方式

    vue子組件通過.sync修飾符修改props屬性方式

    這篇文章主要介紹了vue子組件通過.sync修飾符修改props屬性方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue2中無法檢測到數(shù)組變動的原因及解決

    Vue2中無法檢測到數(shù)組變動的原因及解決

    由于某些限制,vue2不能檢測到某些情況下數(shù)組的變動,本文就將具體講解這兩種限制的解決思路
    2021-06-06
  • vue移動端判斷手指在屏幕滑動方向

    vue移動端判斷手指在屏幕滑動方向

    這篇文章主要為大家詳細(xì)介紹了vue移動端判斷手指在屏幕滑動方向,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06

最新評論