jQuery Tree Multiselect使用详解


Posted in jQuery onMay 02, 2017

树型权限管理插件jQuery Tree Multiselect的使用方法,具体内容如下

1、认识jQuery Tree Multiselect

这个插件允许用户以树型的形式来呈现列表复选框的选择。多用于权限管理中用于分配不同的权限。使用文档,请参考:https://github.com/patosai/tree-multiselect.js

2、运行环境

2.1、需要引入jquery.v1.8+版本和jquery ui.js 2.2、只能在IE8以上的版本中运行

3、效果图展示:

给角色分配权限中,操作栏中有两个按钮:修改和授权

jQuery Tree Multiselect使用详解

点击授权按钮,效果如图:

直观的菜单呈现:

jQuery Tree Multiselect使用详解

右边带有选项标识:

jQuery Tree Multiselect使用详解

4、使用方法及参数描述

4.1、初始化方法:$("select").treeMultiselect();4.2、选择属性名称使用:

jQuery Tree Multiselect使用详解

selected:当给option添加selected属性时,即<option value="monitor_index" selected>首页</option>,改复选框默认为选择状态;
data-section:即当给option添加data-section属性时,展现父子层次关系:

'<option value="monitor_index" data-section="旅游管理" data-description="首页描述" selected>首页</option>' +
'<option value="manage_logs" data-section="旅游管理" data-description="用户日志描述" selected>用户信息</option>' +
'<option value="interface_logs" data-section="旅游管理" data-description="接口调用日志描述" selected>酒店信息</option>' +
'<option value="abnormal_logs" data-section="旅游管理">出行信息</option>' +
'<option value="empty_logs" data-section="旅游管理">景点信息</option>'

data-description:即当给option添加data-description属性时,在复选框后面会有一个问号形式的图标,鼠标放上去,展示描述信息,如图:

jQuery Tree Multiselect使用详解

data-index:即当给option添加data-index属性时,主要用于显示option选项的顺序,最直观的的表现可在右边的div区域内观察。

通过设置 “首页”:data-index = 3, "用户信息":data-index = 2,"酒店信息":data-index = 1,右边的排序如图:
同时会让option变为选中状态。

jQuery Tree Multiselect使用详解

此外,通过设置data-section="接口测试/接口应用/接口筛选",可以设置多层次的展现效果,如图:

jQuery Tree Multiselect使用详解

4.3、参数详解

params为一个对象,你可以通过给treeMultiselect(params)添加不同的参数,来实现不同的效果:
使用方法如:$("#authorifyselect").treeMultiselect({ searchable: true, startCollapsed: false });
其中参数:searchable、collapsible、hideSidePanel、onChange、startCollapsed较为常用和重要,其他参数用户可以根据自己需求添加。

jQuery Tree Multiselect使用详解

allowBatchSelection:用于父菜单复选框的显示和隐藏。默认为true时,父菜单前出现复选框,右侧出现详细选中列表;如图:

jQuery Tree Multiselect使用详解

设置为false时,父菜单前没有复选框,如图:

jQuery Tree Multiselect使用详解

collapsible:用于设置父菜单的展开和伸缩。

默认为true时,父菜单前出现小横线,即可以伸缩;如图:

jQuery Tree Multiselect使用详解

设置为false时,父菜单前没有小横线,即不可以伸缩;如图:

jQuery Tree Multiselect使用详解

enableSelectAll,支持任何选项的选择;默认为false;
设置为true时,出现“Select All”和“Unselect All”选项,可实现全选和全不选功能,如图:

jQuery Tree Multiselect使用详解

selectAllText,当enableSelectAll可用时,可选中所有;
unselectAllText,当enableSelectAll可用时,可不选中所有;
freeze,默认为false,表示对选项禁用选择;设置为true时,效果如图:

jQuery Tree Multiselect使用详解

hideSidePanel:用户隐藏右边的选项面板;默认为false,表示不隐藏;设置为true时,即隐藏;
onChange:默认为null,表示选择选项时触发的回调函数;默认包含四个参数(text:属性文本,value:值,initialIndex,section)

$("#authorifyselect").treeMultiselect({ onChange: function(text, value, initialIndex, section) {
 console.log(text);
 console.log(value);
 console.log(initialIndex);
 console.log(section);
} });

当我点击某个选项时,输出结果如图:

jQuery Tree Multiselect使用详解

即text会输出所有选中的复选框的信息;value会输出你当时点击的那个复选框的信息;这里initialIndex和section的值为空。
onlyBatchSelection:只进行部分检查,只能设置为false.
sortable:默认为false,设置为true时,选择的选项可以通过拖动排序(需要jQuery UI);
searchable,默认为false,设置为true时,菜单顶部会出现搜索框,用于快捷搜索菜单。效果如图:

jQuery Tree Multiselect使用详解

searchParams: ['value', 'text', 'description', 'section'],用于设置搜索设置项。
sectionDelimiter:意思是data-section="value1/value2/value3",可以通过“/”来分隔值,实现多层列表效果。
showSectionOnSelected:默认为true,当选中选项时,显示section name;
startCollapsed:默认为false,设置为true时,菜单默认进来显示为折叠效果,如图:

jQuery Tree Multiselect使用详解

总结:当你在开发用户权限管理的后台系统时,你不妨选择这个插件用于权限的分配。小巧且简单。

代码下载地址为:jQuery Tree Multiselect

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

jQuery 相关文章推荐
jQuery使用ajax_动力节点Java学院整理
Jul 05 jQuery
浅谈jQuery框架Ajax常用选项
Jul 08 jQuery
JS与jQuery判断文本框还剩多少字符可以输入的方法
Sep 01 jQuery
jQuery的ztree仿windows文件新建和拖拽功能的实现代码
Dec 05 jQuery
jQuery实现左右两个列表框的内容相互移动功能示例
Jan 27 jQuery
jQuery操作attr、prop、val()/text()/html()、class属性
May 23 jQuery
jQuery轮播图功能制作方法详解
Dec 03 jQuery
jQuery实现鼠标放置名字上显示详细内容气泡提示框效果的方法分析
Apr 04 jQuery
jQuery 选择方法及$(this)用法实例分析
May 19 jQuery
如何在vue 中引入使用jquery
Nov 10 jQuery
基于jQuery拖拽事件的封装
Nov 29 jQuery
jQuery实现购物车全功能
Jan 11 jQuery
jQuery Ajax自定义分页组件(jquery.loehpagerv1.0)实例详解
May 01 #jQuery
jQuery实现按比例缩放图片的方法
Apr 29 #jQuery
jQuery输入框密码的显示隐藏【代码分享】
Apr 29 #jQuery
jQuery实现多张图片上传预览(不经过后端处理)
Apr 29 #jQuery
jQuery设置图片等比例缩小的方法
Apr 29 #jQuery
node.js+jQuery实现用户登录注册AJAX交互
Apr 28 #jQuery
jQuery使用eraser.js插件实现擦除、刮刮卡效果的方法【附eraser.js下载】
Apr 28 #jQuery
You might like
php中$_SERVER[PHP_SELF] 和 $_SERVER[SCRIPT_NAME]之间的区别
2009/09/05 PHP
js判断变量是否空值的代码
2008/10/26 Javascript
用js模拟JQuery的show与hide动画函数代码
2010/09/20 Javascript
js实现图片放大缩小功能后进行复杂排序的方法
2012/11/08 Javascript
jquery控制左右箭头滚动图片列表的实例
2013/05/20 Javascript
js 赋值包含单引号双引号问题的解决方法
2014/02/26 Javascript
js去除浏览器默认底图的方法
2015/06/08 Javascript
js实现文本框支持加减运算的方法
2015/08/19 Javascript
jquery实现仿新浪微博带动画效果弹出层代码(可关闭、可拖动)
2015/10/12 Javascript
基于jQuery实现的仿百度首页滑动选项卡效果代码
2015/11/16 Javascript
Angular2开发环境搭建教程之VS Code
2017/12/15 Javascript
vue.js $refs和$emit 父子组件交互的方法
2017/12/20 Javascript
关于laydate.js加载laydate.css路径错误问题解决
2017/12/27 Javascript
详解Webstorm 下的Angular2.0开发之路(图文)
2018/12/06 Javascript
Three.js实现3D机房效果
2018/12/30 Javascript
浅谈Vue.js中如何实现自定义下拉菜单指令
2019/01/06 Javascript
使用vue实现多规格选择实例(SKU)
2019/08/23 Javascript
vue实现分页加载效果
2019/12/24 Javascript
Python程序设计入门(4)模块和包
2014/06/16 Python
Python中类的继承代码实例
2014/10/28 Python
Python发送以整个文件夹的内容为附件的邮件的教程
2015/05/06 Python
Python 3 实现定义跨模块的全局变量和使用教程
2019/07/07 Python
python3 dict ndarray 存成json,并保留原数据精度的实例
2019/12/06 Python
opencv python在视屏上截图功能的实现
2020/03/05 Python
Python 判断时间是否在时间区间内的实例
2020/05/16 Python
html5构建触屏网站之touch事件介绍
2013/01/07 HTML / CSS
专门经营化妆刷的美国彩妆品牌:Sigma Beauty
2017/09/11 全球购物
金额转换,阿拉伯数字的金额转换成中国传统的形式如:(¥1011)-> (一千零一拾一元整)输出
2015/05/29 面试题
小学毕业家长寄语
2014/01/19 职场文书
视光学毕业生自荐书范文
2014/02/13 职场文书
学雷锋宣传标语
2014/06/25 职场文书
投标人法定代表人授权委托书格式
2014/09/28 职场文书
团支部组织委员竞选稿
2015/11/21 职场文书
OpenCV-Python实现油画效果的实例
2021/06/08 Python
MySQL系列之三 基础篇
2021/07/02 MySQL
MySQL慢查询中的commit慢和binlog中慢事务的区别
2022/06/16 MySQL