网站首页 > 技术文章 正文
大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力。
什么是 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-06-23 Java中玩转JSON:让数据交互变得简单又有趣
- 2025-06-23 爬虫逆向学习-下载网易云音乐(爬虫逆向分析)
- 2025-06-23 一篇长文带你在Python里玩转Json数据
- 2025-06-23 能运行,不代表它是对的:5 个潜伏在正常功能下的 JavaScript 错误
- 2025-06-23 让Android开发者轻松解析json数据的三种工具
- 2025-06-23 必知必会!Python json模块全解析(python json encode)
- 2025-06-23 JavaScript的Symbol,解决了多少你不知道的隐形大麻烦?
- 2025-06-23 JSON 对象的这些操作和使用场景你知道多少?
- 2025-06-23 JSON 对象的克隆:浅拷贝与深拷贝(jsonobject深拷贝)
- 2025-06-23 JSON文件格式及Python操作详解(jsonpath python)
- 最近发表
-
- Java中玩转JSON:让数据交互变得简单又有趣
- 爬虫逆向学习-下载网易云音乐(爬虫逆向分析)
- 一篇长文带你在Python里玩转Json数据
- 为何推荐 JsonTree.js 做 JSON 可视化?
- 能运行,不代表它是对的:5 个潜伏在正常功能下的 JavaScript 错误
- 让Android开发者轻松解析json数据的三种工具
- 必知必会!Python json模块全解析(python json encode)
- JavaScript的Symbol,解决了多少你不知道的隐形大麻烦?
- JSON 对象的这些操作和使用场景你知道多少?
- JSON 对象的克隆:浅拷贝与深拷贝(jsonobject深拷贝)
- 标签列表
-
- cmd/c (64)
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)