基于jstree使用JSON数据组装成树
发布时间 - 2026-01-11 03:01:01 点击率:次概述:

前面主要是html数据,这里主要是json数组
1.格式
jsTree需要一个具体格式JSON数据,在标准的语法没有那个字段是必须的-而是那些是你需要的。请记住你可以获取任何你请求的其他属性,jsTree将会不会碰他们,你将有可能在随后使用它们。
为了改变节点的图标你可以是用属性icon。具体的字符串需要包含/的一个图片的url路径,你可以使用任何其它字符串应用类样式去修饰<i>元素,它将会被用呈现这个图标。你可以使用boolean 值false来jsTree在渲染节点时没有图标。
你可以设置一个节点的状态使用state属性,它值可以使如下值得组合:opened,selected,disabled.
li_attr和a_attr可以直接通过jQuery属性函数获取。
当使用AJAX设置children为false,jsTree将会将渲染这个节点为关闭状态,如果需要打开的时候需要发送额外的请求。
如何内部children都应该遵循相同的格式,或者是普通字符串(这个字符串作为普通文本和任何其它自动生成的)
// Expected format of the node (there are no required fields)
{
id : "string" // will be autogenerated if omitted
text : "string" // node text
icon : "string" // string for custom
state : {
opened : boolean // is the node open
disabled : boolean // is the node disabled
selected : boolean // is the node selected
},
children : [] // array of strings or objects
li_attr : {} // attributes for the generated LI node
a_attr : {} // attributes for the generated A node
}
2.可选择JSON格式
如果你不想使用内部children的方式,你可以使用可选语法,每个节点需要包含两个必须字段:id和parent,没有children属性(其它都保持这个格式)
jsTree将会自动构建这个层次关系,为表明一个节点应该是根节点可是设置parent属性为"#".
这个种方式大多数用于一次性渲染整棵树,这个数据存储在数据库之间有联结关系。
为了使用JSON来渲染一棵树,你需要使用$.jstree.defaults.core.data配置选项
这个希望格式为一个数组节点。每个节点应该是一个如上所描述的对象或者是一个简单的字符串(这种情况字符串被用来作为一个节点的文本替换自动生成的文本),任何内部子节点格式是一样的。
// Alternative format of the node (id & parent are required)
{
id : "string" // required
parent : "string" // required
text : "string" // node text
icon : "string" // string for custom
state : {
opened : boolean // is the node open
disabled : boolean // is the node disabled
selected : boolean // is the node selected
},
li_attr : {} // attributes for the generated LI node
a_attr : {} // attributes for the generated A node
}
3.使用JSON
为了使用JSON来渲染一棵树,你需要使用$.jstree.defaults.core.data配置选项。
这个希望格式为一个数组节点。每个节点应该是一个如上所描述的对象或者是一个简单的字符串(这种情况字符串被用来作为一个节点的文本替换自动生成的文本),任何内部子节点格式是一样的。
$('#using_json').jstree({ 'core' : {
'data' : [
'Simple root node',
{
'text' : 'Root node 2',
'state' : {
'opened' : true,
'selected' : true
},
'children' : [
{ 'text' : 'Child 1' },
'Child 2'
]
}
]
} });
4.使用可选json格式
$('#using_json_2').jstree({ 'core' : {
'data' : [
{ "id" : "ajson1", "parent" : "#", "text" : "Simple root node" },
{ "id" : "ajson2", "parent" : "#", "text" : "Root node 2" },
{ "id" : "ajson3", "parent" : "ajson2", "text" : "Child 1" },
{ "id" : "ajson4", "parent" : "ajson2", "text" : "Child 2" },
]
} });
5.使用AJAX
你可以使用AJAX向服务器请求返回一个json数据来渲染树,这个格式如上所示,这里唯一不同就是JSON是不可见,它是服务器返回的。
为了使用这个特性,你需要使用$.jstree.defaults.core.data配置选项。
仅仅是使用标准jquery像AJAX配置和jstree将会自动做出一个AJAX请求而返回数据。
除了标准jQuery ajax选项,你可以提供data函数和url路径,这个功能将会运行当前的实例范围内,一个参数被通过表明这个节点被加载了,这个返回值将会用作各自的URL和data。
如果你并不会返回json头部信息,至少设置数据类型 jQuery AJAX的选项为“json”。
6.使用函数
你可以提供一个函数,这个函数将会接受两个参数,节点加载和回调函数。
$('#tree').jstree({
'core' : {
'data' : function (obj, cb) {
cb.call(this,
['Root 1', 'Root 2']);
}
}});
# JSON
# 树
# jstree
# 基于jstree使用AJAX请求获取数据形成树
# jstree创建无限分级树的方法【基于ajax动态创建子节点】
# 基于BootStrap Metronic开发框架经验小结【二】列表分页处理和插件JSTree的使用
# jsTree 基于JQuery的排序节点 Bug
# jquery下jstree简单应用 - v1.0
# jquery.jstree 增加节点的双击事件代码
# 基于jsTree的无限级树JSON数据的转换代码
# JQery jstree 大数据量问题解决方法
# jsTree树控件(基于jQuery
# 超强悍)[推荐]
# jsTree事件和交互以及插件plugins详解
# 你可以
# 将会
# 是一个
# 如果你
# 自动生成
# 这种情况
# 作为一个
# 可选
# 一棵树
# 格式为
# 主要是
# 加载
# 有可能
# 是一样的
# 它是
# 或者是
# 仅仅是
# 可以直接
# 所示
# 你将
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】
零服务器AI建站解决方案:快速部署与云端平台低成本实践
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载
如何在IIS中新建站点并解决端口绑定冲突?
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】
如何快速搭建FTP站点实现文件共享?
javascript基本数据类型及类型检测常用方法小结
Laravel怎么使用artisan命令缓存配置和视图
MySQL查询结果复制到新表的方法(更新、插入)
Python文本处理实践_日志清洗解析【指导】
Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程
历史网站制作软件,华为如何找回被删除的网站?
C#如何调用原生C++ COM对象详解
网站制作价目表怎么做,珍爱网婚介费用多少?
微信h5制作网站有哪些,免费微信H5页面制作工具?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
百度输入法ai组件怎么删除 百度输入法ai组件移除工具
如何用低价快速搭建高质量网站?
如何在新浪SAE免费搭建个人博客?
Laravel如何集成Inertia.js与Vue/React?(安装配置)
Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践
Laravel如何使用Sanctum进行API认证?(SPA实战)
Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】
微信小程序 input输入框控件详解及实例(多种示例)
如何快速打造个性化非模板自助建站?
如何在阿里云购买域名并搭建网站?
Laravel如何自定义错误页面(404, 500)?(代码示例)
如何在Windows服务器上快速搭建网站?
edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】
Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】
JavaScript如何实现倒计时_时间函数如何精确控制
Laravel如何生成API文档?(Swagger/OpenAPI教程)
Python面向对象测试方法_mock解析【教程】
如何快速生成橙子建站落地页链接?
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
如何自定义建站之星模板颜色并下载新样式?
Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】
PythonWeb开发入门教程_Flask快速构建Web应用
Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件
Android利用动画实现背景逐渐变暗
Laravel怎么判断请求类型_Laravel Request isMethod用法
网站图片在线制作软件,怎么在图片上做链接?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析
Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康
如何在云服务器上快速搭建个人网站?
laravel怎么通过契约(Contracts)编程_laravel契约(Contracts)编程方法
如何快速搭建高效WAP手机网站吸引移动用户?

