jsTree事件和交互以及插件plugins详解
发布时间 - 2026-01-11 03:01:05 点击率:次本文为大家分享了jsTree事件和交互以及插件plugins,供大家参考,具体内容如下

1、事件
jsTree在容器中触发变量事件,你可以浏览所有事件,然后了解如何进行监听:https://www.jstree.com/api/#/?q=.jstree%20Event
通过data参数获取更多详细信息关于事件检查。
更多情况下就是你会得到所有节点对象,如果你通过ID获取这个节点,查看节点使用.get_node().
$('#jstree')
// listen for event
.on('changed.jstree', function (e, data) {
var i, j, r = [];
for(i = 0, j = data.selected.length; i < j; i++) {
r.push(data.instance.get_node(data.selected[i]).text);
}
$('#event_result').html('Selected: ' + r.join(', '));
})
// create the instance
.jstree();
2.交互
为了在一个实例中调用一个方法,你必须要获取实例引用然后调用方法,这个例子展示如何获取一个引用然后调取一个方法。
可以查看API获取更多的方法:https://www.jstree.com/api/#/?q=(
// 3 ways of doing the same thing
$('#jstree').jstree(true)
.select_node('mn1');
$('#jstree')
.jstree('select_node', 'mn2');
$.jstree.reference('#jstree')
.select_node('mn3');
3、插件
jsTree有些功能被移除核心,只有你需要的时候才使用它,为了确保使用插件,需要使用plugins参数配置选项,将插件名称添加到一个数组中。
举个例子确保所有插件都可以使用:(只要设置你需要使用的插件)
"plugins" : [ "checkbox", "contextmenu", "dnd", "massload", "search", "sort", "state", "types", "unique", "wholerow", "changed", "conditionalselect" ]
这里有快速预览每一个插件
3.1、changed plugin (改变插件)
这个插件添加关于选择改变的额外的信息,一旦包含plugins配置选项,每个changed.jstree事件数据将会包含一个新的属性名称为changed,它将给出最后关于seleted和deselected节点的事件(changed.jstree)
$(function () {
$("#plugins")
.on("changed.jstree", function (e, data) {
console.log(data.changed.selected); // newly selected
console.log(data.changed.deselected); // newly deselected
})
.jstree({
"plugins" : [ "changed" ]
});
});
3.2.checked plugin(复选框)
这个插件将会在每个节点前面渲染复选框的图标,使得多选变得更加容易。
它也支持三态,意味着一个节点有些子节点是选中,这个节点将会被渲染成未确定,这个状态可以传播。你可以通过级联配置选项来微调级联选项。
记住级联会复选框会检查所有节点,即使是不可用的节点。
不确定状态是一个自动计算的,但是如果你是使用AJAX加载形成树想要渲染一个节点作为不确定状态通过设置属性“undetermined”:true。
你可以在API找到所有配置复选框的选项https://www.jstree.com/api/#/?q=$.jstree.defaults.checkbox
$(function () {
$("#plugins1").jstree({
"checkbox" : {
"keep_selected_style" : false
},
"plugins" : [ "checkbox" ]
});
});
3.3 conditionalselect plugin(条件插件)
这个插件重写了activate_node函数(就是用户选择节点将会调用的函数),你可以通过回调避免这个函数被调用。
$(function () {
$("#plugins10").jstree({
"conditionalselect" : function (node, event) {
return false;
},
"plugins" : [ "conditionalselect" ]
});
});
3.4(Contextmenu plugin)上下文菜单插件
这插件就是你在一个节点上右键会弹出一个功能列表菜单。
你可以通过API找所有contextmenu插件的配置选项:点击打开链接
$(function () {
$("#plugins2").jstree({
"core" : {
// so that create works
"check_callback" : true
},
"plugins" : [ "contextmenu" ]
});
});
3.5 (drag&drop)拖拽插件
这个插件可以通过拖拽来重新改变树的结构。
你可以通过API找到更多的配置选项:点击打开链接
3.6.Massloadplugin(惯性负载插件)
这个插件通过一次请求(使用的是延迟加载)加载节点
你可以通过API找到更多的配置选项:点击打开链接
$(function () {
$("#plugins10").jstree({
"core" : {
"data" : { .. AJAX config .. }
},
"massload" : {
"url" : "/some/path",
"data" : function (nodes) {
return { "ids" : nodes.join(",") };
}
}
"plugins" : [ "massload", "state" ]
});
});
3.7.(search plugin) 搜索插件
这个插件可以在一棵树搜索对应的条目。
你可以通过API找到更多的配置选项:点击打开链接
$("#plugins4").jstree({
"plugins" : [ "search" ]
});
var to = false;
$('#plugins4_q').keyup(function () {
if(to) { clearTimeout(to); }
to = setTimeout(function () {
var v = $('#plugins4_q').val();
$('#plugins4').jstree(true).search(v);
}, 250);
});
});
3.8. sort plugin(排序插件)
这个插件可以重新对于同一级的条目进行排序,默认采用数字或26字母的顺序,你可以通过配置对比函数:点击打开链接
$(function () {
$("#plugins5").jstree({
"plugins" : [ "sort" ]
});
});
3.9.state plugin(状态插件)
这个插件保存所有打开和选中的节点到用户浏览器中,所以当再次返回相同的树,先前的状态将会被恢复
你可以通过API获取更多状态插件的配置选项:点击打开链接,你可以通过选中一个节点,然后刷新该页面就可以看到变化。
$(function () {
$("#plugins6").jstree({
"state" : { "key" : "demo2" },
"plugins" : [ "state" ]
});
});
3.10. types plugin(类型插件)
这个插件为一组节点预先定义类型,这就意味着为每个组很容易控制内部规则和图标。
为了设置节点类型,你可以使用set_type 或者在data中提供一个type属性
你可以通过API获取更多关于类型插件的配置选项和函数:点击打开链接
$(function () {
$("#plugins7").jstree({
"types" : {
"default" : {
"icon" : "glyphicon glyphicon-flash"
},
"demo" : {
"icon" : "glyphicon glyphicon-ok"
}
},
"plugins" : [ "types" ]
});
})
3.11. unique plugin(唯一插件)
同一层级的条目不能出现相同的名称。这个插件没有选项,它只是避免在同一节点的重命名和移动其它节点时出现相同的名称。
$(function () {
$("#plugins8").jstree({
"core" : {
"check_callback" : true
},
"plugins" : [ "unique", "dnd" ]
});
});
3.12 wholerow plugin (整行插件)
这个插件就是一个条目占满一行,方便选择,如果是一个很大的树它可能会导致在老的浏览器变慢。
$(function () {
$("#plugins9").jstree({
"plugins" : [ "wholerow" ]
});
});
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# jsTree
# plugins
# 基于jstree使用AJAX请求获取数据形成树
# 基于jstree使用JSON数据组装成树
# jstree创建无限分级树的方法【基于ajax动态创建子节点】
# 基于BootStrap Metronic开发框架经验小结【二】列表分页处理和插件JSTree的使用
# jsTree 基于JQuery的排序节点 Bug
# jquery下jstree简单应用 - v1.0
# jquery.jstree 增加节点的双击事件代码
# 基于jsTree的无限级树JSON数据的转换代码
# JQery jstree 大数据量问题解决方法
# jsTree树控件(基于jQuery
# 超强悍)[推荐]
# 你可以
# 将会
# 复选框
# 是一个
# 加载
# 级联
# 不确定
# 的是
# 拖拽
# 如果你
# 你是
# 你会
# 你在
# 右键
# 很容易
# 这就
# 可以通过
# 弹出
# 写了
# 即使是
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
PHP 500报错的快速解决方法
Laravel如何使用Passport实现OAuth2?(完整配置步骤)
Laravel怎么实现支付功能_Laravel集成支付宝微信支付
潮流网站制作头像软件下载,适合母子的网名有哪些?
Laravel如何使用Eloquent进行子查询
高端网站建设与定制开发一站式解决方案 中企动力
如何注册花生壳免费域名并搭建个人网站?
黑客如何通过漏洞一步步攻陷网站服务器?
免费视频制作网站,更新又快又好的免费电影网站?
如何在阿里云香港服务器快速搭建网站?
装修招标网站设计制作流程,装修招标流程?
企业网站制作这些问题要关注
微信h5制作网站有哪些,免费微信H5页面制作工具?
Python制作简易注册登录系统
Linux网络带宽限制_tc配置实践解析【教程】
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
Windows10如何更改计算机工作组_Win10系统属性修改Workgroup
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
实例解析Array和String方法
微信公众帐号开发教程之图文消息全攻略
专业商城网站制作公司有哪些,pi商城官网是哪个?
高性价比服务器租赁——企业级配置与24小时运维服务
jquery插件bootstrapValidator表单验证详解
HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】
Python自动化办公教程_ExcelWordPDF批量处理案例
Laravel如何配置任务调度?(Cron Job示例)
如何用wdcp快速搭建高效网站?
猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】
网站制作报价单模板图片,小松挖机官方网站报价?
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
Laravel怎么解决跨域问题_Laravel配置CORS跨域访问
Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧
如何用JavaScript实现文本编辑器_光标和选区怎么处理
WordPress 子目录安装中正确处理脚本路径的完整指南
Python高阶函数应用_函数作为参数说明【指导】
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
JavaScript中的标签模板是什么_它如何扩展字符串功能
如何用IIS7快速搭建并优化网站站点?
HTML 中如何正确使用模板变量为元素的 name 属性赋值
Laravel如何生成和使用数据填充?(Seeder和Factory示例)
Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能
电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?
如何在Windows服务器上快速搭建网站?
如何用免费手机建站系统零基础打造专业网站?
JavaScript如何实现音频处理_Web Audio API如何工作?
如何登录建站主机?访问步骤全解析
高端建站如何打造兼具美学与转化的品牌官网?
html5的keygen标签为什么废弃_替代方案说明【解答】
,怎么在广州志愿者网站注册?

