树形组件的使用小结

<el-tree
      :data="tabledata"
      show-checkbox
      node-key="id"
      ref="tree"
      highlight-current
      :props="defaultProps"
      :default-checked-keys="selectList"
      @check="handleCheckChange"
      :check-strictly="isChecked"
      class="mt-2"
    >
    //isChecked初始化为false父子节点联动
    //default-checked-keys赋值后端返回来的选中数组,配合node-key使用
    //check选中事件
    </el-tree>

js部分代码:

 methods: {
    getList(id) {
      this.$axios.rolepermList({ role_id: id }).then((res) => {
        if (res.data.code == 200) {
          this.tabledata = res.data.data.list;
          this.isChecked = true //取消父子节点联动

          this.$nextTick(()=>{
            this.selectList= res.data.data.selected;
            this.isChecked = false//将选中的节点赋值之后再将父子节点联动,才可全选和取消全选
          })
        }
      });
    },
    handleCheckChange() {
      let list = this.$refs.tree.getCheckedKeys();//获取选中的节点
      let half = this.$refs.tree.getHalfCheckedKeys();//获取半选中的节点
      let obj = {
        role_id: this.id,
        selected: list.concat(half)//合并两个数组
      };
      this.$axios
        .saveRoleperm(obj)
        .then((res) => {
          // console.log("selected????", res);
          if (res.data.code == 200) {
            this.$message.success(res.data.message);
          }
        });
    },

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值