当前位置: 首页 > news >正文

树多选搜索查询,搜索后选中状态仍保留

<template><div class="half-transfer"><div class="el-transfer-panel"><div><el-checkbox v-model="selectAll" @change="handleSelectAll">全部</el-checkbox></div><el-input v-model="searchInput" placeholder="请输入搜索内容" clearable @clear="clearSearch"></el-input><div class="el-transfer__list"><el-treeref="treeRef":data="treeData"node-key="key":default-expand-all="true"show-checkbox:default-checked-keys="checkedKeys":filter-node-method="filterNode"@check="handleCheckChange"></el-tree></div></div></div>
</template><script setup>
import { ref, reactive, watch, nextTick } from 'vue';
import { ElTree, ElCheckbox, ElInput } from 'element-plus';const searchInput = ref('');
const checkedKeys = ref([]);
const treeData = reactive([{key: 1,label: '选项1',children: [{ key: 11, label: '子选项11' },{ key: 12, label: '子选项12' },{ key: 13, label: '子选项13' },],},{key: 2,label: '选项2',children: [{ key: 21, label: '子选项21' },{ key: 22, label: '子选项22' },{ key: 23, label: '子选项23' },],},
]);
const selectAll = ref(false);
const treeRef = ref(null);watch(searchInput, (val) => {treeRef.value.filter(val);
});const filterNode = (value, data) => {if (!value) return true;return data.label.includes(value);
};const clearSearch = () => {searchInput.value = '';
};const handleSelectAll = (checked) => {if (checked) {checkedKeys.value = getAllNodeKeys();} else {checkedKeys.value = [];treeRef.value.setCheckedKeys([]);}
};const getAllNodeKeys = () => {const keys = [];const traverse = (nodes) => {for (const node of nodes) {keys.push(node.key);if (node.children && node.children.length > 0) {traverse(node.children);}}};traverse(treeData);return keys;
};const handleCheckChange = (data) => {checkedKeys.value = data.checkedKeys;// 获取树节点选中的idconsole.log(treeRef.value.getCheckedKeys())nextTick(() => {if (treeRef.value) {const nodes = treeRef.value.root.childNodes;const allChecked = nodes.every((node) => node.checked);selectAll.value = allChecked;}});
};
</script><style scoped>
.half-transfer {margin-top: 20px;margin-left: 20px;width: 335px;height: 260px;background: #fff;padding: 20px;border: 1px solid #dcdfe6;border-radius: 4px;
}.el-transfer-panel {display: flex;flex-direction: column;height: 100%;
}.el-transfer__list {overflow-y: auto;border-radius: 4px;margin-top: 8px;
}.el-transfer__list .el-checkbox-group {padding: 10px;
}.el-transfer__list .el-checkbox {display: block;margin-bottom: 5px;line-height: 24px;
}.el-transfer__list .el-checkbox:last-child {margin-bottom: 0;
}.el-transfer__list .el-scrollbar {background-color: #f5f7fa;
}
</style>

http://www.lryc.cn/news/146818.html

相关文章:

  • 数据结构--字典树(trie)
  • iframe通过postMessage进行跨域通信以及在Angular中使用
  • rust学习-引用C库
  • WebAssembly 在云原生中的实践指南
  • Azure sqlserver 更改字符集
  • git push时,由于commit了大文件无法成功push的解决办法
  • 2023_Spark_实验一:Windows中基础环境安装
  • 如何在Windows / Mac / iPhone / Android / Online上将MP4转换为MP3
  • 【App端】uni-app使用百度地图api和echarts省市地图下钻
  • 深度学习(十)--- cv2.pointPolygonTest() 判断一点是否在指定区域内
  • 后端面试话术集锦第 八 篇:redis面试话术
  • LiteOS qemu realview-pbx-a9 环境搭建与运行
  • Kubernetes技术--Kubernetes架构组件以及核心概念
  • 拿来即用修改密码功能
  • 违背原则才能写好代码(一)
  • 面试官眼中的理想候选人:如何成为他们的首选
  • ES6中的扩展运算符你真的会用吗?
  • 利用逻辑回归判断病人肺部是否发生病变
  • 全民健康生活方式行动日,天猫健康联合三诺生物推出“15天持续测糖计划”
  • 设计模式行为型-状态模式
  • 弹窗、抽屉、页面跳转区别 | web交互入门
  • 说说Flink运行模式
  • 视频汇聚/视频云存储/视频监控管理平台EasyCVR新增首次登录强制修改密码
  • C语言控制语句——分支语句
  • 音视频 fmpeg命令裁剪和合并视频
  • 机器学习基础17-基于波士顿房价(Boston House Price)数据集训练模型的整个过程讲解
  • 哈希的应用——布隆过滤器
  • LNMT的多机部署和双机热备
  • 软件测试/测试开发丨Pytest和Allure报告 学习笔记
  • 十七、命令模式