ztree实现权限横向显示功能


Posted in Javascript onMay 20, 2017

 最近在做权限功能的时候,采用的ztree实现的,但是产品要求最后一层的权限节点要横向显示。开始在网上找的解决方案是用css样式把最后一层的display设置为inline。在我本地电脑上看了下。效果不错。

但是,后来测试在用十年前的笔记本测这个功能的时候,发现特别的卡,导致浏览器都崩溃了。所以,性能优化开始了。

1、同步改为异步,虽然不卡,但是功能不满足,很多人勾选了一个父节点(模块节点),就保存,此时子节点根本没有,所以保存的数据是有问题的。

2、设置showIcon和showLine为false,发现速度有一丢丢的提升,但是产品还是不满意。

3、仔细看了下,ztree的checkbox都是用span模拟的,搞个背景图。凭直觉觉得用原生的checkbox要比用图片模拟要强一些。说干就干,找了ztree提供的一个例子,稍作改造,效果还是很明显的。用到的主要方法时addDiyDom。

下面把主要的代码贴上来。

1、数据结构,要求有一个isLeaf节点,标记是否是子节点。

var zNodes =[
      { id:1, pId:0, name:"父节点 1", open:true,isLeaf:false},
      { id:11, pId:1, name:"叶子节点 1-1",isLeaf:true},
      { id:12, pId:1, name:"叶子节点 1-2",open:true,isLeaf:false},
      { id:120, pId:12, name:"叶子节点 1-2-0",isLeaf:true},
      { id:121, pId:12, name:"叶子节点 1-2-1",isLeaf:true},
      { id:13, pId:1, name:"叶子节点 1-3",isLeaf:true},
      { id:2, pId:0, name:"父节点 2", open:true,isLeaf:false},
      { id:21, pId:2, name:"叶子节点 2-1",isLeaf:true},
      { id:22, pId:2, name:"叶子节点 2-2",isLeaf:true},
      { id:23, pId:2, name:"叶子节点 2-3",isLeaf:true},
      { id:3, pId:0, name:"父节点 3", open:true,isLeaf:false},
      { id:31, pId:3, name:"叶子节点 3-1",isLeaf:true},
      { id:32, pId:3, name:"叶子节点 3-2",isLeaf:true},
      { id:33, pId:3, name:"叶子节点 3-3",isLeaf:true}
    ];

2、addDiyDom方法

function addDiyDom(treeId, treeNode) {
      //console.log(treeNode);
      var aObj = $("#" + treeNode.tId + IDMark_A);
      var editStr = $("<input type='checkbox' class='checkboxBtn' id='checkbox_" +treeNode.id+ "' onclick='checkedHandler(this)' ></input>");
      editStr.data("treeNode",treeNode);
      aObj.before(editStr);
    
    }

3、自己写的几个级联操作的方法

function checkedHandler(checkbox){
      var $checkbox = $(checkbox),
        treeNode = $checkbox.data("treeNode"),
        state = checkbox.checked;
        if(treeNode.isLeaf){ //子节点
          if(state){ //子节点选中,父节点要跟着选中,子节点取消选择,父节点不用级联
            setParentNodeChecked(checkbox);
          }
        }else{ //父节点
          if(state){ //选中,级联子节点,级联父节点
            setParentNodeChecked(checkbox);
            setChildNodeChecked(checkbox);
          }else{
            setChildNodeChecked(checkbox);
          }
        }
    }
    /**设置父节点选中 */
    function setParentNodeChecked(checkbox){
      var $pNode = $(checkbox).closest("ul").parent();
      var pCheckbox = $pNode.find(".checkboxBtn").get(0);
      var treeNode = $(pCheckbox).data("treeNode");
      if(pCheckbox.checked === checkbox.checked) return;
      pCheckbox.checked = checkbox;
      if(treeNode.pId != "0") setParentNodeChecked(pCheckbox);
    }
    /**设置子节点选中 */
    function setChildNodeChecked(checkbox){
      $(checkbox).closest("li").find(".checkboxBtn").each(function(){
        this.checked = checkbox.checked;
      });
    }

4、css中,设置:

.ztree li.isLeaf{
display:inline;
 }

以上所述是小编给大家介绍的ztree实现权限横向显示功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的,在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
关于JavaScript中var声明变量作用域的推断
Dec 16 Javascript
关于捕获用户何时点击window.onbeforeunload的取消事件
Mar 06 Javascript
前端必备神器 Snap.svg 弹动效果
Nov 10 Javascript
Vue.js每天必学之计算属性computed与$watch
Sep 05 Javascript
JS添加或修改控件的样式(Class)实现方法
Oct 15 Javascript
React中使用collections时key的重要性详解
Aug 07 Javascript
jQuery实现的简单获取索引功能示例
Jun 04 jQuery
在vue中使用vue-echarts-v3的实例代码
Sep 13 Javascript
详解Vue项目引入CreateJS的方法(亲测可用)
May 30 Javascript
jQuery实现手风琴效果(蒙版)
Jan 11 jQuery
vue keep-alive实现多组件嵌套中个别组件存活不销毁的操作
Oct 30 Javascript
如何vue使用el-table遍历循环表头和表体数据
Apr 26 Vue.js
神级程序员JavaScript300行代码搞定汉字转拼音
May 20 #Javascript
在使用JSON格式处理数据时应该注意的问题小结
May 20 #Javascript
微信小程序利用co处理异步流程的方法教程
May 20 #Javascript
关于jQuery库冲突的完美解决办法
May 20 #jQuery
layui文件上传实现代码
May 20 #Javascript
为你的微信小程序体积瘦身详解
May 20 #Javascript
jquery.guide.js新版上线操作向导镂空提示jQuery插件(推荐)
May 20 #jQuery
You might like
星际争霸兵种名称对照表
2020/03/04 星际争霸
setcookie中Cannot modify header information-headers already sent by错误的解决方法详解
2013/05/08 PHP
php 去除html标记--strip_tags与htmlspecialchars的区别详解
2013/06/26 PHP
ThinkPHP中公共函数路径和配置项路径的映射分析
2014/11/22 PHP
PHP编写的图片验证码类文件分享
2016/06/06 PHP
浅谈PHP中try{}catch{}的使用方法
2016/12/09 PHP
asp函数split()对应php函数explode()
2019/02/27 PHP
jQuery Div中加载其他页面的实现代码
2009/02/27 Javascript
Js+Jq获取URL参数的集中方法示例代码
2014/05/20 Javascript
jquery插件hiAlert实现网页对话框美化
2015/05/03 Javascript
JQuery中上下文选择器实现方法
2015/05/18 Javascript
JavaScript记录光标在编辑器中位置的实现方法
2016/04/22 Javascript
一分钟理解js闭包
2016/05/04 Javascript
基于jquery实现图片放大功能
2016/05/07 Javascript
浅谈jquery点击label触发2次的问题
2016/06/12 Javascript
vue2.0 keep-alive最佳实践
2017/07/06 Javascript
Vue v2.5 调整和更新不完全问题
2017/10/24 Javascript
基于 Vue.js 2.0 酷炫自适应背景视频登录页面实现方式
2018/01/17 Javascript
vue实现桌面向网页拖动文件的示例代码(可显示图片/音频/视频)
2021/03/01 Vue.js
python BeautifulSoup设置页面编码的方法
2015/04/03 Python
调试Python程序代码的几种方法总结
2015/04/28 Python
python清除函数占用的内存方法
2018/06/25 Python
Python面向对象之反射/自省机制实例分析
2018/08/24 Python
python同时遍历数组的索引和值的实例
2018/11/15 Python
Python测试模块doctest使用解析
2019/08/10 Python
Python散点图与折线图绘制过程解析
2019/11/30 Python
django框架ModelForm组件用法详解
2019/12/11 Python
python爬虫开发之Beautiful Soup模块从安装到详细使用方法与实例
2020/03/09 Python
Python sklearn中的.fit与.predict的用法说明
2020/06/28 Python
Python如何把字典写入到CSV文件的方法示例
2020/08/23 Python
社区优秀志愿者先进事迹
2014/05/09 职场文书
收款授权委托书
2014/10/02 职场文书
认错检讨书
2014/10/02 职场文书
结婚典礼致辞
2015/07/28 职场文书
win11系统中dhcp服务异常什么意思? Win11 DHCP服务异常修复方法
2022/04/08 数码科技
uniapp引入支付宝原生扫码插件步骤详解
2022/07/23 Javascript