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

网站通内容管理系统金融理财网站建设

网站通内容管理系统,金融理财网站建设,郑州定制网站开发,昆明seo外包上一篇文章记录的是自己将树状数据转换为表格形式。但是出现了一个小bug,点击子节点时候会选中父节点,这个是正常需求没问题。但是我点击父节点时候取消所有子节点,父节点 选择也会失去,这是我不想要执行的。例如一个页面里面有主…

上一篇文章记录的是自己将树状数据转换为表格形式。但是出现了一个小bug,点击子节点时候会选中父节点,这个是正常需求没问题。但是我点击父节点时候取消所有子节点,父节点 选择也会失去,这是我不想要执行的。例如一个页面里面有主页,各种小组件,但是我只想看一个主页,小组件都不要了。而不是我如果想要看主页必须最少选择一个组件。

代码:

el-tree的组件方法

check-change节点选中状态发生变化时的回调共三个参数,依次为:传递给 data 属性的数组中该节点所对应的对象、节点本身是否被选中、节点的子树中是否有被选中的节点
check当复选框被点击的时候触发共两个参数,依次为:传递给 data 属性的数组中该节点所对应的对象、树目前的选中状态对象,包含 checkedNodes、checkedKeys、halfCheckedNodes、halfCheckedKeys 四个属性

<el-treeshow-checkbox:data="allMenu":default-expand-all="true"node-key="permissionId"ref="menuTree"check-strictlyhighlight-current:props="xxxxx"empty-text="暂未匹配到信息"@check="handleCheck"@check-change="handleCheckChange"></el-tree>

一、递归调用获取所有的节点ID

setChecked通过 key / data 设置某个节点的勾选状态,使用此方法必须设置 node-key 属性(key/data, checked, deep) 接收三个参数,1. 勾选节点的 key 或者 data 2. boolean 类型,节点是否选中 3. boolean 类型,是否设置子节点 ,默认为 false

这里为什么不使用带S的。肯定是这个方法有问题。

setCheckedKeys通过 keys 设置目前勾选的节点,使用此方法必须设置 node-key 属性

(keys, leafOnly) 接收两个参数,1. 勾选节点的 key 的数组 2. boolean 类型的参数,若为 true 则仅设置叶子节点的选中状态,默认值为 false

selectChildren(data) {if (data && data.sonPermissionList) {// 如果数据存在且有子权限列表data.sonPermissionList.map((item) => {// 将子节点的权限设置为勾选状态this.$refs.menuTree.setChecked(item.permissionId, true);if (data.sonPermissionList) {// 如果子权限列表存在,则递归调用 selectChildren 方法this.selectChildren(item);}});}
}

二,点击复选框事件

在点击时候能获取到当前的树目前的选中状态对象,包含 checkedNodes、checkedKeys、halfCheckedNodes、halfCheckedKeys 四个属性

handleCheck(data, { checkedKeys }) {// 第二个参数使用解构赋值获取选中状态的对象 checkedKeys// 使用 includes 方法判断当前节点的权限ID是否包含在 checkedKeys 中。如果包含,则调用 selectChildren 方法。if (checkedKeys.includes(data.permissionId)) {this.selectChildren(data);}
},

三、在点击复选框时候 进行父子节点的处理

handleCheckChange(data, checked, indeterminate) {if (checked === false) {if (data.sonPermissionList) {// 如果当前节点被取消勾选data.sonPermissionList.map((item) => {// 将子节点的权限设置为取消勾选状态this.$refs.menuTree.setChecked(item.permissionId, false);});}} else {if (data.pid !== null) {// 如果当前节点被勾选,并且有父节点this.$refs.menuTree.setChecked(data.pid, true);}}// 获取勾选状态的节点数组var check = this.$refs.menuTree.getCheckedNodes();// 提取节点数组中的权限ID,并去重var idList = check.map((item) => {this.permissionIdList = [];return item.permissionId;});this.permissionIdList.push(...idList);// 对去重后的权限ID列表进行过滤this.permissionIdList = this.permissionIdList.filter((item, index) => {return this.permissionIdList.indexOf(item, 0) === index;});
}

http://www.yayakq.cn/news/725231/

相关文章:

  • 做网站要那些工具企业如何申请网址
  • 万网域名跳转到指定网站北京城市副中心投资建设公司网站
  • 怎么做网站地图的样式中山企业集团网站建设
  • 广州网站建设要多少钱王烨烨
  • 网站做支付宝支付需要哪些资料哪家建站公司好
  • 网站样版风格排版网站布局设计步骤
  • 精品课程网站建设总结报告投资域名后悔死了
  • 不用买服务器可以做网站展会网站制作
  • 氧化锌网站建设网站建设海报图片
  • 怎么建设一个宣传网站东营建筑信息网
  • 芜湖新芜湖网站建设中企动力科技有限公司
  • 怎么做frontpage网站燕郊网站建设哪家好
  • 做网站网站的人是怎么被抓的网站维护合同范本
  • 毕业设计网站做几个页面wordpress的登陆地址修改
  • 郑州hi宝贝网站建设公司西安企业信息查询官网
  • 焦作音响网站建设网站开发设置用户
  • 做ppt网站有哪些内容吗国家重大建设项目库网站
  • 企业网站托管价格黄冈网站推广优化技巧
  • 拍卖网站开发多少钱哈尔滨制作网站工作室
  • 域名注册网站有哪些网站开发 手机 电脑
  • 2_网站建设的一般步骤包含哪些?黄石网站建设推荐
  • 网站建设分析魅族网页游戏排行榜20
  • 公司网站推广费用北京市城市建设档案馆网站首页
  • 问答类咨询网站的建设gps定位网站建设
  • 什么是网站内链云尚网络科技有限公司域名主机
  • thinkphp做的教育网站设计师网站外网
  • 这么建立com的网站知名企业网站大全
  • 上海网站建设最好的公司网站申请微信支付
  • 网站建设与维护的软件网站文章列表如何排版
  • 受欢迎的佛山网站制作wordpress 样式表