网站首页 > 技术文章 正文
大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力。
什么是 JsonTree.js
A lightweight JavaScript library that generates customizable tree views to better visualize JSON data.
JsonTree.js 是 一个轻量级 JavaScript 库,可生成可自定义的树视图以更好地可视化 JSON 数据,其具有以下突出特征:
- 零依赖性且非常轻量
- 可导出以用于其他框架
- 可通过公共函数获得完整 API
- 完全采用 CSS/SASS 样式,完全响应,并与 Bootstrap 库兼容
- 完全支持 CSS 主题(使用 :root 变量)
- 每个 DOM 元素完全可配置,支持关闭 / 打开全部
- 可点击值、自定义值渲染
JsonTree.js 完全支持所有现代浏览器,例如: Google Chrome、FireFox 和 Opera 等。
如何使用 JsonTree.js
首先安装相应依赖:
npm install jjsontree.js
// 也可以通过 CDN 引入
https://cdn.jsdelivr.net/gh/williamtroup/JsonTree.js@1.1.2/dist/jsontree.min.js
https://cdn.jsdelivr.net/gh/williamtroup/JsonTree.js@1.1.2/dist/jsontree.export.min.js
https://cdn.jsdelivr.net/gh/williamtroup/JsonTree.js@1.1.2/dist/jsontree.js.min.css接着包含以下内容:
<link rel="stylesheet" href="dist/jsontree.js.css">
<script src="dist/jsontree.js"></script>然后进行 DOM 树绑定:
<div id="tree-1" data-jsontree-js="{'showCounts': true,'data': [ true, false, 5, 10,'A String'] }">
Your HTML.
</div>当然,开发者还可以通过自定义函数的方式来处理,比如:
<div id="json-tree-1" data-jsontree-js="bindingOptions"></div>下面是 bindingOptions 方法的内容:
function bindingOptions() {
return {
showCounts: false,
data: {
value1: true,
value2: "This is a string",
value3: new Date(),
value4: 5,
value7: null,
value8: function() {
// Does nothing
},
value9: 3.1415926535,
value5: [
true,
"This is another string",
{
arrayValue1: true,
arrayValue2: 10
},
[
false,
true,
5,
10,
new Date()
]
],
value6: {
objectValue1: false,
objectValue2: "This is a new string",
objectValue3: 20
}
}
}
}当然,JsonTree.js 还允许开发者使用配置选项,其允许自定义 JsonTree.js 的运行方式,比如下面的示例:
<script>
$jsontree.setConfiguration( {
safeMode: false
} );
</script>更多关于 JsonTree.js 的用法和示例可以参考文末资料,本文不再过多展开。
参考资料
https://www.william-troup.com/jsontree-js/documentation/options.html
猜你喜欢
- 2025-09-06 每天一个 Python 库:json 数据读写技巧合集,实战最常用!
- 2025-09-06 Python 使用 JsonPath 完成接口自动化测试中参数关联和数据验证
- 2025-09-06 String 类型和 Hash 类型的结构比较
- 2025-09-06 50 道高频 JavaScript 面试题,从基础到进阶 (附答案)
- 2025-09-06 性能飞跃!V8 引擎官宣 JSON.stringify 速度提升 >200% !
- 2025-09-06 99% 的人都遇到的 JSON 错误, jsonrepair 修复一气呵成!
- 2025-09-06 零基础入门AI智能体:详细了解什么是变量类型、JSON结构、Markdown格式
- 2025-09-06 36. JSON 解析速成,三库实战揭秘
- 2025-06-23 Java中玩转JSON:让数据交互变得简单又有趣
- 2025-06-23 爬虫逆向学习-下载网易云音乐(爬虫逆向分析)
- 最近发表
-
- 聊一下 gRPC 的 C++ 异步编程_grpc 异步流模式
- [原创首发]安全日志管理中心实战(3)——开源NIDS之suricata部署
- 超详细手把手搭建在ubuntu系统的FFmpeg环境
- Nginx运维之路(Docker多段构建新版本并增加第三方模
- 92.1K小星星,一款开源免费的远程桌面,让你告别付费远程控制!
- Go 人脸识别教程_piwigo人脸识别
- 安卓手机安装Termux——搭建移动服务器
- ubuntu 安装开发环境(c/c++ 15)_ubuntu安装c++编译器
- Rust开发环境搭建指南:从安装到镜像配置的零坑实践
- Windows系统安装VirtualBox构造本地Linux开发环境
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- c语言min函数头文件 (77)
- asynccallback (87)
- localstorage.removeitem (77)
- vector线程安全吗 (73)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 无效的列索引 (74)
