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

Element樹(shù)形控件el-tree實(shí)現(xiàn)一鍵全選、反選功能

 更新時(shí)間:2023年10月10日 10:49:51   作者:@.十七  
最近做的項(xiàng)目用到了全選全不選功能,于是就自己動(dòng)手寫(xiě)了一個(gè),這篇文章主要給大家介紹了關(guān)于Element樹(shù)形控件el-tree實(shí)現(xiàn)一鍵全選、反選功能的相關(guān)資料,需要的朋友可以參考下

前言

本篇文章將詳細(xì)講解  vue3+Element Plus  項(xiàng)目中如何實(shí)現(xiàn)el-tree組件的一鍵全選反選功能:點(diǎn)擊一鍵全選時(shí),將選中所有的節(jié)點(diǎn),當(dāng)節(jié)點(diǎn)未被全部選中時(shí) ,全選框?yàn)榘脒x狀態(tài)。(最后有增加vue2+element ui 實(shí)現(xiàn)代碼)

vue3+Element Plus具體實(shí)現(xiàn):

模板部分:

1,在合適位置(如el-tree同級(jí))新增一個(gè)復(fù)選框組件 el-checkbox

<el-checkbox size="mini" :indeterminate="isIndeterminate" v-model="checkAll" 
@change="handleCheckAllChange" style="padding:0px;margin-right:5px;">
全選</el-checkbox>

步驟詳解:

(1) indeterminate 屬性用以表示 checkbox 的不確定狀態(tài),一般用于實(shí)現(xiàn)全選的效果;

(2)v-model  綁定的值控制全選框是否為選中狀態(tài);

(3)@change是狀態(tài)改變時(shí)觸發(fā)的事件。

2,給el-tree組件綁定ref屬性,node-key屬性,以及 @check-change事件

<el-tree ref="testingTree" :data="testingData" :props="testingProps" 
show-checkbox @check-change="testCheckChange" node-key="path" />

步驟詳解:

(1) 在vue3中同樣是以ref屬性來(lái)獲取元素;

(2)check-change 事件當(dāng)復(fù)選框被點(diǎn)擊的時(shí)候觸發(fā);

(3)node-key 節(jié)點(diǎn)標(biāo)識(shí)  通常用id,實(shí)際開(kāi)發(fā)根據(jù)后端數(shù)據(jù)來(lái)確定就好。 

JS邏輯部分

3,實(shí)現(xiàn)全選及反選邏輯(代碼有點(diǎn)長(zhǎng),我會(huì)逐句講解)

//一鍵全選
    let checkAll = ref(false) //全選按鈕的綁定值
    let isIndeterminate = ref(false) //全選按鈕的全選,半選樣式 
    const testingTree = ref(null) //在vue3中使用ref獲取元素需要在setup中進(jìn)行聲明一個(gè)同名變量
    //1.1獲取當(dāng)前選中的節(jié)點(diǎn)
    function testCheckChange() {
      // 獲取Tree組件的實(shí)例,使用ref聲明的變量在邏輯代碼中使 用時(shí)需加 .value
      const tree = testingTree.value; 
      let checkedCount = 0;//被勾選上的一級(jí)節(jié)點(diǎn)個(gè)數(shù)
      let disabledCount = 0;//置灰的一級(jí)節(jié)點(diǎn)個(gè)數(shù)
      let indeterminateFlag = false;//有沒(méi)有一級(jí)節(jié)點(diǎn)處于半選狀態(tài)
      //遍歷所有一級(jí)節(jié)點(diǎn)(testingData為el-tree組件:data的值)
      for (let i = 0; i < testingData.value.length; i++) {
    //getNode為el-tree組件的實(shí)例方法,可以根據(jù) data 或者 key 拿到 Tree 組件中的 node
        if (tree.getNode(testingData.value[i]).disabled == true) {
          disabledCount += 1;//如果有置灰的節(jié)點(diǎn),置灰變量加1
        }
        if (tree.getNode(testingData.value[i]).checked == true) {
          checkedCount += 1;//如果有勾選的節(jié)點(diǎn),勾選變量加1
        }
        if (tree.getNode(testingData.value[i]).indeterminate == true) {
          indeterminateFlag = true;//如果有半選的節(jié)點(diǎn),半選變量設(shè)為true
        }
      }
      if (checkedCount == 0) {
        isIndeterminate.value = false;
        checkAll.value = false;//如果勾選的一級(jí)節(jié)點(diǎn)數(shù)為0,則設(shè)置全選按鈕樣式不為半選樣式,全選的值為false
        if (indeterminateFlag == true) {//如果下面有半選的,設(shè)置全選按鈕的樣式為半選樣式
          isIndeterminate.value = true;
          checkAll.value = false;
        }
      }
      else if ((checkedCount + disabledCount) == testingData.value.length) {//如果樹(shù)上勾上的和置灰的加起來(lái)等于tree上data的長(zhǎng)度,設(shè)置全選按鈕樣式不為半選樣式,全選值為true
        isIndeterminate.value = false;
        checkAll.value = true;
      }
      else {//上面條件不滿足,則說(shuō)明沒(méi)有全部勾上,設(shè)置樣式為半選,全選值為false
        isIndeterminate.value = true;
        checkAll.value = false;
      }
      return;
    }
//全選按鈕勾上的方法事件
    function handleCheckAllChange(val) {
      isIndeterminate.value = false;//設(shè)置全選按鈕樣式不為半選
      if (checkAll.value == true) {
//如果是當(dāng)前值是全選,依次遍歷節(jié)點(diǎn)設(shè)置勾選,同時(shí)過(guò)濾的disabled為true的
        for (let i = 0; i < testingData.value.length; i++) {
          if (testingTree.value.getNode(testingData.value[i]).disabled == false) {
            testingTree.value.setChecked(testingData.value[i].path, true, true);
          }
        }
      }
      else {
//取消全選時(shí)置空
        testingTree.value.setCheckedKeys([])
      }

vue2+Element ui具體實(shí)現(xiàn):

<template>
  <div>
    <el-checkbox size="mini" :indeterminate="isIndeterminate"  v-model="new_task_form.case_checkAll" @change="handleCheckAllChange" style="padding:0px;margin-right:5px;">全選</el-checkbox>
  </div>
  <el-tree
     style="max-height: 200px;overflow: auto;"
     :data="casedata"
     show-checkbox
     :default-expand-all="false"
     node-key="id"
     ref="casetree"
     highlight-current
     :props="defaultPorps"
      @check-change="case_check_change">
   </el-tree>
</template>
data(){
    return {
        new_task_form:{
            "case_checkAll":false //全選按鈕的綁定值
        },
        isIndeterminate:false,//全選按鈕的全選,半選樣式 
    }
},
methods:{
    case_check_change(node1,node2,node3){//樹(shù)節(jié)點(diǎn)check事件
            let checked_count = 0;//被勾選上的一級(jí)節(jié)點(diǎn)個(gè)數(shù)
            let disabled_count = 0;//置灰的一級(jí)節(jié)點(diǎn)個(gè)數(shù)
            let indeterminate_flag = false;//有沒(méi)有一級(jí)節(jié)點(diǎn)處于半選狀態(tài)
            //遍歷所有一級(jí)節(jié)點(diǎn)
            for(let i=0;i<this.casedata.length;i++){
                if(this.$refs.casetree.getNode(this.casedata[i]).disabled==true){
                    disabled_count += 1;//如果有置灰的節(jié)點(diǎn),置灰變量加1
                }
                if(this.$refs.casetree.getNode(this.casedata[i]).checked==true){
                    checked_count += 1;//如果有勾選的節(jié)點(diǎn),勾選變量加1
                }
                if(this.$refs.casetree.getNode(this.casedata[i]).indeterminate==true){
                    indeterminate_flag = true;//如果有半選的節(jié)點(diǎn),半選變量設(shè)為true
                }
            }
            if(checked_count==0){
                this.isIndeterminate = false;
                this.new_task_form.case_checkAll = false;//如果勾選的一級(jí)節(jié)點(diǎn)數(shù)為0,則設(shè)置全選按鈕樣式不為半選樣式,全選的值為false
                if(indeterminate_flag==true){//如果下面有半選的,設(shè)置全選按鈕的樣式為半選樣式
                    this.isIndeterminate = true;
                    this.new_task_form.case_checkAll = false;
                }
            }
            else if((checked_count+disabled_count)==this.casedata.length){//如果樹(shù)上勾上的和置灰的加起來(lái)等于tree上data的長(zhǎng)度,設(shè)置全選按鈕樣式不為半選樣式,全選值為true
                this.isIndeterminate = false;
                this.new_task_form.case_checkAll = true;
            }
            else{//上面條件不滿足,則說(shuō)明沒(méi)有全部勾上,設(shè)置樣式為半選,全選值為false
                this.isIndeterminate = true;
                this.new_task_form.case_checkAll = false;
            }
            return;
        },
        handleCheckAllChange(val){//全選按鈕勾上的方法事件
            this.isIndeterminate = false;//設(shè)置全選按鈕樣式不為半選
            if(this.new_task_form.case_checkAll==true){//如果是當(dāng)前值是全選,依次遍歷節(jié)點(diǎn)設(shè)置勾選,同時(shí)過(guò)濾的disabled為true的
                for(let i=0;i<this.casedata.length;i++){
                    if(this.$refs.casetree.getNode(this.casedata[i]).disabled==false){
                        this.$refs.casetree.setChecked(this.casedata[i].id,true,true);
                    }
                }
            }
            else{//當(dāng)前值不是全選,設(shè)置勾選列表為空
                 this.$refs.casetree.setCheckedKeys([]);
            }
        },
}

總結(jié) 

到此這篇關(guān)于Element樹(shù)形控件el-tree實(shí)現(xiàn)一鍵全選、反選功能的文章就介紹到這了,更多相關(guān)el-tree一鍵全選反選內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue項(xiàng)目接入高德地圖點(diǎn)擊地圖獲取經(jīng)緯度以及省市區(qū)功能

    vue項(xiàng)目接入高德地圖點(diǎn)擊地圖獲取經(jīng)緯度以及省市區(qū)功能

    這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目接入高德地圖點(diǎn)擊地圖獲取經(jīng)緯度以及省市區(qū)功能的相關(guān)資料,開(kāi)發(fā)中我們需要地圖定位,就是用戶輸入位置,自動(dòng)定位獲取經(jīng)緯度,需要的朋友可以參考下
    2023-08-08
  • vuedraggable實(shí)現(xiàn)簡(jiǎn)單拖拽功能

    vuedraggable實(shí)現(xiàn)簡(jiǎn)單拖拽功能

    這篇文章主要為大家詳細(xì)介紹了vuedraggable實(shí)現(xiàn)拖拽功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue-element如何實(shí)現(xiàn)動(dòng)態(tài)換膚存儲(chǔ)

    vue-element如何實(shí)現(xiàn)動(dòng)態(tài)換膚存儲(chǔ)

    這篇文章主要介紹了vue-element如何實(shí)現(xiàn)動(dòng)態(tài)換膚存儲(chǔ)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Vue之Watcher源碼解析(1)

    Vue之Watcher源碼解析(1)

    這篇文章主要為大家詳細(xì)介紹了Vue源碼之Watcher的基礎(chǔ)知識(shí),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • vue axios整合使用全攻略

    vue axios整合使用全攻略

    這篇文章主要介紹了vue axios整合使用全攻略,需要的朋友可以參考下
    2018-05-05
  • vue axios請(qǐng)求成功卻進(jìn)入catch的原因分析

    vue axios請(qǐng)求成功卻進(jìn)入catch的原因分析

    這篇文章主要介紹了vue axios請(qǐng)求成功卻進(jìn)入catch的原因分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-09-09
  • 10分鐘帶你上手Vue3中新增的API

    10分鐘帶你上手Vue3中新增的API

    這篇文章主要介紹了10分鐘教你快速上手Vue3中新增的API,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-09-09
  • Vue Router中的冗余導(dǎo)航錯(cuò)誤及解決方案

    Vue Router中的冗余導(dǎo)航錯(cuò)誤及解決方案

    在現(xiàn)代前端開(kāi)發(fā)中,單頁(yè)應(yīng)用(SPA)已經(jīng)成為主流,而 Vue.js 作為一款流行的前端框架,其官方路由庫(kù) Vue Router 則是構(gòu)建 SPA 的核心工具之一,在使用 Vue Router 的過(guò)程中,開(kāi)發(fā)者可能會(huì)遇到一些常見(jiàn)的錯(cuò)誤,本文將深入探討這一錯(cuò)誤的原因、影響以及解決方案
    2025-01-01
  • Vue編程三部曲之將template編譯成AST示例詳解

    Vue編程三部曲之將template編譯成AST示例詳解

    這篇文章主要為大家介紹了Vue編程三部曲之將template編譯成AST示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • Vue.js實(shí)現(xiàn)可排序的表格組件功能示例

    Vue.js實(shí)現(xiàn)可排序的表格組件功能示例

    這篇文章主要介紹了Vue.js實(shí)現(xiàn)可排序的表格組件功能,涉及vue.js事件響應(yīng)、元素動(dòng)態(tài)操作、排序、運(yùn)算等相關(guān)操作技巧,需要的朋友可以參考下
    2019-02-02

最新評(píng)論