el-tree 实现全选、反选、子选父功能

html部分

<el-tree

:data="menuList"

:props="menuListTreeProps"

node-key="permId"

:accordion="true"

ref="menuListTree"

:check-strictly="trueFlag"

:default-expand-all="true"

:default-checked-keys="checkKeys"

@check-change="checkChange"

@check="currentChecked"

show-checkbox>

</el-tree>

 

data部分

data () {

return {

menuList: [],

treeNewArr: [],

disabledTrue: true,

chekedKeys: [],

treeData: [],

trueFlag: true,

editCheckId: '',

checkKeys: [],

menuListTreeProps: {

label: 'permName',

children: 'sub',

// disabled: 'hasperm'

},

 

js 部分

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现全选功能,需要在el-tree中使用el-checkbox组件,并通过一些JavaScript代码来监听中状态的变化。 以下是一个实现全选功能的示例代码: ```html <el-tree :data="treeData" node-key="id" show-checkbox @check-change="handleCheckChange"> <template slot-scope="{ node, data }"> <span>{{ node.label }}</span> <el-checkbox v-model="data.checked" :indeterminate="data.indeterminate" @change="handleCheckChange"></el-checkbox> </template> </el-tree> ``` 在上述代码中,el-tree组件设置了show-checkbox属性,表示显示复框;使用了el-checkbox组件来实现框的功能。 同时,在el-checkbox组件中,绑定了v-model来实现数据的双向绑定,以及@change事件来监听复框状态的变化。 在JavaScript中,需要实现一个handleCheckChange方法来处理复框状态的变化,具体实现如下: ```js methods: { handleCheckChange(nodeData) { if (nodeData.checked) { // 中节点 this.checkNode(nodeData, true); } else { // 取消中节点 this.checkNode(nodeData, false); } }, checkNode(nodeData, checked) { nodeData.checked = checked; if (nodeData.children && nodeData.children.length > 0) { // 处理节点 nodeData.children.forEach(childNode => { this.checkNode(childNode, checked); }); } const parentNode = this.getParentNode(nodeData); if (parentNode) { // 更新节点状态 this.updateParentNode(parentNode); } }, getParentNode(nodeData) { let parentNode = null; let currentNode = nodeData; while (currentNode && !parentNode) { currentNode = currentNode.parent; if (currentNode && currentNode.level === 0) { parentNode = currentNode.data; } } return parentNode; }, updateParentNode(nodeData) { let checkedCount = 0; let indeterminateCount = 0; nodeData.children.forEach(childNode => { if (childNode.checked) { checkedCount++; } else if (childNode.indeterminate) { indeterminateCount++; } }); if (checkedCount === nodeData.children.length) { // 所有节点都中了 nodeData.checked = true; nodeData.indeterminate = false; } else if (checkedCount === 0) { // 所有节点都没有中 nodeData.checked = false; nodeData.indeterminate = false; } else { // 部分节点中 nodeData.checked = false; nodeData.indeterminate = true; } const parentNode = this.getParentNode(nodeData); if (parentNode) { // 更新节点状态 this.updateParentNode(parentNode); } } } ``` 在上述代码中,handleCheckChange方法用来处理复框状态变化的逻辑,checkNode方法用来递归处理节点的状态,updateParentNode方法用来更新节点的状态。由于el-tree中的数据是静态的,所以需要自己维护节点的关系。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值