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

生产企业做网站有用吗网站开发微信支付

生产企业做网站有用吗,网站开发微信支付,网站建设搭配,在那里做网站el-tree的使用及控制全选、反选、获取选中 组件使用获取选中的id全选实现反选实现全部代码 组件使用 引入组件&#xff0c;可以参考官网组件引入参考官网示例写好基础数据结构&#xff0c;不知道怎么转换树形机构的看文章&#xff1a;一维数组转树形 <template><el-…

el-tree的使用及控制全选、反选、获取选中

  • 组件使用
  • 获取选中的id
  • 全选实现
  • 反选实现
  • 全部代码

组件使用

  1. 引入组件,可以参考官网组件引入
  2. 参考官网示例写好基础数据结构,不知道怎么转换树形机构的看文章:一维数组转树形
<template><el-treestyle="max-width: 600px":data="data":props="props"show-checkbox/>
</template><script setup>
const handleNodeClick = (data) => {console.log(data)
}const data = [{label: 'Level one 1',children: [{label: 'Level two 1-1',children: [{label: 'Level three 1-1-1',},],},],},{label: 'Level one 2',children: [{label: 'Level two 2-1',children: [{label: 'Level three 2-1-1',},],},{label: 'Level two 2-2',children: [{label: 'Level three 2-2-1',},],},],},{label: 'Level one 3',children: [{label: 'Level two 3-1',children: [{label: 'Level three 3-1-1',},],},{label: 'Level two 3-2',children: [{label: 'Level three 3-2-1',},],},],},
]const props= {children: 'children',label: 'label',
}
</script>

获取选中的id

通过获取tree组件,操作方法进行获取

  1. 给组件绑定一个ref
<el-tree ref="treeRef" node-key="id" style="max-width: 600px" :props="props" :data="data" show-checkbox />
  1. 声明变量
const treeRef = ref(null)
  1. 操作组件方法
// 获取选中数据
const handleCheckChange = () => {// 方法一:获取key,此方法必须设置属性node-key!!!console.log(treeRef.value.getCheckedKeys(false))// 返回被选中的key,也就是id// 方法二:获取节点nodeconsole.log(treeRef.value.getCheckedNodes(false))// 返回被选中的对象
}

全选实现

思路:获取全部的key,也就是id,然后通过赋值的操作来实现效果

// 用于判断是全选还是取消
let isAll = false;
// 全选
const all = () => {if (isAll) {treeRef.value.setCheckedKeys([], false)isAll = false} else {// 获取所以的id,如果有一维数组,则直接循环获取即可const nodeKeys = [];function getAllKeys(data) {data.forEach(node => {nodeKeys.push(node.id);if (node.children) {getAllKeys(node.children);}});}getAllKeys(treeData.value);treeRef.value.setCheckedKeys(nodeKeys, false)isAll = true}
}

反选实现

思路:

  1. 获取当前选中的key
  2. 全部选中
  3. 将第一步获取的key节点设置为取消
// 反选
const reverse = () => {// 1. 获取当前选中的keylet checked = treeRef.value.getCheckedKeys(false);// 2. 全部选中const nodeKeys = [];function getAllKeys(data) {data.forEach(node => {nodeKeys.push(node.id);if (node.children) {getAllKeys(node.children);}});}getAllKeys(treeData.value);treeRef.value.setCheckedKeys(nodeKeys, false)// 3. 将第一步获取的key节点设置为取消checked.forEach(val => {treeRef.value.setChecked(val, false)})
}

全部代码

<template><el-treestyle="max-width: 600px":data="data":props="props"show-checkboxref="treeRef"/><el-button type="primary" @click="handleCheckChange">获取选中数据</el-button><el-button type="primary" @click="all">全选</el-button><el-button type="primary" @click="reverse">反选</el-button>
</template><script setup>
import { ref } from 'vue';
const treeRef = ref(null)
const handleNodeClick = (data) => {console.log(data)
}const data = [{label: 'Level one 1',children: [{label: 'Level two 1-1',children: [{label: 'Level three 1-1-1',},],},],},{label: 'Level one 2',children: [{label: 'Level two 2-1',children: [{label: 'Level three 2-1-1',},],},{label: 'Level two 2-2',children: [{label: 'Level three 2-2-1',},],},],},{label: 'Level one 3',children: [{label: 'Level two 3-1',children: [{label: 'Level three 3-1-1',},],},{label: 'Level two 3-2',children: [{label: 'Level three 3-2-1',},],},],},
]const props= {children: 'children',label: 'label',
}
// 获取选中数据
const handleCheckChange = () => {// 方法一:获取key,此方法必须设置属性node-key!!!console.log(treeRef.value.getCheckedKeys(false))// 返回被选中的key,也就是id// 方法二:获取节点nodeconsole.log(treeRef.value.getCheckedNodes(false))// 返回被选中的对象
}// 用于判断是全选还是取消
let isAll = false;
// 全选
const all = () => {if (isAll) {treeRef.value.setCheckedKeys([], false)isAll = false} else {// 获取所以的id,如果有一维数组,则直接循环获取即可const nodeKeys = [];function getAllKeys(data) {data.forEach(node => {nodeKeys.push(node.id);if (node.children) {getAllKeys(node.children);}});}getAllKeys(treeData.value);treeRef.value.setCheckedKeys(nodeKeys, false)isAll = true}
}// 反选
const reverse = () => {// 1. 获取当前选中的keylet checked = treeRef.value.getCheckedKeys(false);// 2. 全部选中const nodeKeys = [];function getAllKeys(data) {data.forEach(node => {nodeKeys.push(node.id);if (node.children) {getAllKeys(node.children);}});}getAllKeys(treeData.value);treeRef.value.setCheckedKeys(nodeKeys, false)// 3. 将第一步获取的key节点设置为取消checked.forEach(val => {treeRef.value.setChecked(val, false)})
}
</script>
http://www.yayakq.cn/news/27021/

相关文章:

  • 小学最好的网站建设网页升级中紧急自动转跳中
  • 广州 济南网站建设公司 网络服务上海网站定制设计
  • 阜新网站开发常州网站推广培训
  • fusion做电影网站卡死纪检部门网站举报建设
  • 宜宾市珙县住房城乡建设网站海南直聘网
  • 自己做网站排名好吗wordpress 梦月酱
  • 阜新门户网站建设腾讯云服务器
  • 个人网站 网站教程自学网站开发需要看什么书
  • 贵阳做网站的公司厦门建设网站公司
  • 能免费做封面的网站wordpress 移动端 主题
  • 百度站长平台网站验证已经有域名 怎么修改网站
  • 华为模板建站网络规划设计师月薪多少
  • 阿里云esc建设网站企业网站后台模板
  • 天峨县建设局网站网站怎么分工做
  • 做网站一定要用cms吗wordpress调用网站标题
  • 爬取数据做网站健身房网站建设
  • 自己怎么做视频网站泉州服装网站建设
  • 小说网站开发过程 实训报告沈阳seo搜索排名优化
  • 网站建设的销售术语微软手机做网站服务器
  • 只做瓶子包装设计的创意网站电脑网站视频怎么下载
  • 前端网站建设插件2345网址导航怎么关
  • 关于实验室建设的英文网站企业核名
  • 网站建设和咨询服务合同网站开发
  • 怎么做百度采购网站抖音代运营合作策划书
  • 两个网站 一个域名石家庄哪家公司做网络推广好
  • 培训类 网站后台台山住房和城乡建设 网站
  • 怎样与知名网站做友情链接视频网站直播怎么做
  • 做网站都有什么功能六 网站建设方案.
  • 广州专门做网站的公司广东高端网站建设
  • 上海工程建设安全协会网站舆情监测系统方案