vue3 + element plus 树组件 实现左侧勾选树节点 右侧渲染树结构 包括树节点限选、删除

最终效果如下

在这里插入图片描述

解决思路

我们使用非懒加载树,使用同一数据,在勾选左侧树节点的时候,通过 element自带的filter 方法来过滤树节点,筛选出右侧的树形结构

代码片段如下

HTML

<p>已选择 {{ checkedList.keys.length }} / 10</p>
// 左侧树
<el-tree
  ref="treeLeftRef"
  :data="treeData" // 数据
  :props="treeProps" // 配置选项
  :default-checked-keys="checkedList.keys" // 设置默认选中
  show-checkbox // 显示勾选框
  node-key="name" // 每个树节点用来作为唯一标识
  @check="handleChecked" // 勾选树节点时触发
>
  <template #default="{ node, data }"> //自定义树节点
    <span>{{ data.name }} </span>
  </template>
</el-tree>
// 右侧树
<el-tree
  v-show="checkedList.keys.length > 0"
  ref="treeRightRef"
  :data="treeData"
  :props="treeProps"
  node-key="name"
  :filter-node-method="filterRightTree" // 右侧树的过滤方法
>
  <template #default="{ node, data }"> // 自定义树节点
    <span
      >{{ data.name }}
      // 删除小图标
      <img
        src="@/img/垃圾桶.png"
        alt="删除"
        @click="handleDelete(data)" 
      />
    </span>
  </template>
</el-tree>

JS

// 左侧树ref
const treeLeftRef = ref("");
// 右侧树ref
const treeRightRef = ref("");
// 数据
const treeData= ref([
	{
	    "children": [
	        {
	            "children": [
	                {
	                    "name": 1101
	                }
	            ],
	            "disabled": true,
	            "name": "1层"
	        }
	    ],
	    "disabled": true,
	    "name": "1栋"
	},
	{
	    "children": [
	        {
	            "children": [
	                {
	                    "name": 2101
	                 }
	             ],
	             "disabled": true,
	             "name": "1层"
	         }
	     ],
	     "disabled": true,
	     "name": "2栋"
	 }
]);
// 配置选项
const treeProps = {
  label: "name",
  children: "children",
  isLeaf: "isLeaf",
  disabled: "disabled", //前两层不可勾选
};
// 存储已选节点
const checkedList = ref([]);
// 右侧树过滤方法
function filterRightTree(value, data) {
  if (!value) return true;
  return value.includes(data.name);
}
// 左侧树勾选方法
function handleChecked(node, data) {
  if (checkedList.value.keys.length < 10) {
    checkedList.value.keys = treeLeftRef.value.getCheckedKeys(true);
   // 在此处调用过滤方法 筛选出右侧树节点
    treeRightRef.value.filter(checkedList.value.keys);
  } else {
    treeLeftRef.value.setChecked(node.name, false);
    ElMessage({
      message: "已选择10间",
      type: "warning",
    });
  }
}
// 右侧树删除按钮
function handleDelete(data) {
  // 删除左侧树勾选节点
  treeLeftRef.value.setChecked(data.name, false);
  // 重新获取左侧树勾选节点
  checkedList.value.keys = treeLeftRef.value.getCheckedKeys(true);
  // 调用过滤方法
  treeRightRef.value.filter(checkedList.value.keys);
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,下面是实现tabs选项卡切换时展现各自的页面的步骤: 1. 在Vue3中定义两个组件,一个是包含选项卡的父组件,另一个是选项卡面板对应的子组件。 2. 在父组件中使用`el-tabs`和`el-tab-pane`组件实现选项卡,并将每个选项卡面板对应的子组件包含在`el-tab-pane`组件中。 ``` <template> <el-tabs v-model="activeTab"> <el-tab-pane label="Tab 1" name="1"> <tree-1 /> </el-tab-pane> <el-tab-pane label="Tab 2" name="2"> <tree-2 /> </el-tab-pane> </el-tabs> </template> <script> import Tree1 from './Tree1.vue' import Tree2 from './Tree2.vue' export default { components: { Tree1, Tree2 }, data() { return { activeTab: '1' } } } </script> ``` 3. 在每个子组件中分别实现对应的树形结构,并在`mounted`钩子函数中初始化树形结构。 ``` <template> <div class="tree"> <el-tree :data="treeData" :props="treeProps" :default-expanded-keys="['1']" node-key="id" /> </div> </template> <script> export default { data() { return { treeData: [ { id: 1, label: 'Node 1', children: [ { id: 2, label: 'Node 1-1' }, { id: 3, label: 'Node 1-2' } ] } ], treeProps: { children: 'children', label: 'label' } } }, mounted() { // 初始化树形结构 } } </script> ``` 4. 在父组件中使用`keep-alive`组件包含每个子组件,这样在切换选项卡时,之前打开的选项卡对应的子组件的状态就能被保留下来。 ``` <template> <el-tabs v-model="activeTab"> <el-tab-pane label="Tab 1" name="1"> <keep-alive> <tree-1 /> </keep-alive> </el-tab-pane> <el-tab-pane label="Tab 2" name="2"> <keep-alive> <tree-2 /> </keep-alive> </el-tab-pane> </el-tabs> </template> ``` 以上就是实现tabs选项卡切换时展现各自的页面的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值