- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我有一些像这样的 JSON(键/值因隐私原因而改变)。它基本上是一个带有“子”对象数组的对象,每个元素都有自己的“子”对象数组,等等。
{
"name": "Main Area",
"children": [
{
"name": "Sub-section A",
"children": [
{
"name": "Procedure 1"
"children": [
{
"name": "Sub-procedure A",
"children": null
},
{
"name": "Sub-procedure A",
"children": null
},
{
"name": "Sub-procedure A",
"children": null
}
]
},
{
"name": "Procedure 2"
"children": [
{
"name": "Sub-procedure A",
"children": null
},
{
"name": "Sub-procedure A",
"children": null
},
{
"name": "Sub-procedure A",
"children": null
}
]
},
{
"name": "Procedure 3"
"children": [
{
"name": "Sub-procedure A",
"children": null
},
{
"name": "Sub-procedure A",
"children": null
},
{
"name": "Sub-procedure A",
"children": null
}
]
},
]
}
]
}
...随着我的进行,它可能会变得更大/更深几倍。这里的目标是将此数据转换为(可折叠的) TreeMap ,然后使用 knockout.js(最好)将其显示在 HTML 页面上。尽管所有逻辑都必须是 JavaScript 代码(使用 jQuery AJAX 获取 JSON,以某种方式处理它,并显示它)。
像这样然后才旋转 90 度,这样它就会向下而不是向侧面。 http://www.education.vic.gov.au/images/content/studentlearning/mathscontinuum/icecream.gif
现在我知道那里有像 jsTree 这样的库,但关键是我希望这也成为一种学习体验,所以我想在这里创建我自己的代码。此外,jsTree 将其结构打印为目录树。我正在寻找的是一个更直观的自上而下的 TreeMap ,它填充了页面的整个宽度。
问题是,我卡住了。我只是无法理解所有这些嵌套的数组/对象。我可能花了大约 3 个小时尝试一些事情,创建了几个不同的函数来递归遍历整个数组,但我无法让它正常工作。
我想到的最新想法是以某种方式遍历 JSON 结构,从最深的元素开始,向上移动,以某种方式将步骤转换为 TreeMap 级别,直到我到达顶部,此时它完成了。
那么,愿意为我指明正确的方向吗?您不必为我编写几十行代码,只需给我一个指示,也许是一些伪代码,告诉我应该把它带到哪里。
提前致谢!
更新
我说得有点远了。只是想我会分享我的代码以供将来引用。我现在有一个填充的节点对象数组和一个基本的 ul/li 结构(以后仍然可以向它抛出 knockout.js)。仍然需要弄清楚 CSS/JS 部分,但这会随着我的进行而出现。
值得注意的是,我把JSON结构中的每一个“null”值都改成了“[]”,这样用起来更方便。
//node class
function node(label, children, node_id, parent_id) {
this.label = label;
this.children = children;
this.node_id = node_id;
this.parent_id = parent_id;
}
//tree class
function tree(root) {
var self = this;
self.root = root;
if(!$.isArray(self.root.children)) {
return;
}
self.nodeCount = 0;
self.nodes = []; //This will be the main node array
//Adds nodes to the array, recursive
self.addNode = function(_node) {
self.nodeCount++;
self.nodes.push(_node);
//Check if the branch ends here
if(_node.children.length < 1) {
return;
}
var tmpParent = _node;
//Add children
for(var i = 0; i < _node.children.length; i++) {
self.addNode(new node(_node.children[i].name, _node.children[i].children, self.nodeCount, tmpParent.node_id));
}
}
self.draw = function() {
//Populate nodes array
self.rootNode = new node(self.root.name, self.root.children, 0, -1);
self.addNode(self.rootNode); //Kicks off the recursion
//Create the first/"root" node
$(".tree-wrapper").append('<ul id="0"><li class="title">'+ self.rootNode.label +'</li></ul>');
//Create nodes and populate them with children
for(var i = 0; i < self.nodes.length; i++) {
//Check if the node has children
if(self.nodes[i].children.length > 0) {
//Wrap a new <ul> in a <li>, add a title <li> to the created <ul>
$("#"+ self.nodes[i].parent_id).append('<li><ul id="'+ self.nodes[i].node_id +'"><li class="title">'+ self.nodes[i].label +'</li></ul></li>');
} else {
//Simply append a <li> with a label to the parent <ul>
$("#"+ self.nodes[i].parent_id).append('<li id="'+ self.nodes[i].node_id +'">'+ self.nodes[i].label +'</li>');
}
}
}
}
感谢所有回答的人!如果您有提示/技巧,请不要犹豫;)我的代码可能会以某种方式缩短/优化!
最佳答案
我最近实现了完全相同的东西,带有挖空,但使用 DOM 元素呈现,而不是 Canvas 。
我是怎么做到的:
<script ko template = "node">
<div class="node">
<a href="#" data-bind="click: toggleChildren()">Open children</a>
<div class="children" data-bind="visible: childrenOpen, foreach: children, template: node">
</div>
</div>
</script ko template>
<div class="nodes" data-bind="foreach: children, template: node">
</div>
在 ViewModel 方面:
function MyVM() {
this.nodes = ko.observable([]); // this is a list of Node objects. each Node object has a list of children, that are also Node objects
}
ko.applyBindings(new MyVM());
在模型方面:
function Node(name, etc.) {
var self = this;
this.childrenOpen = ko.observable(false);
this.children = ko.observable([]);
this.toggleChildren = function() {
self.childrenOpen(!self.childrenOpen());
}
}
剩下要做的就是:1) 填充 ViewModel 上的节点;2) 编写 CSS,使其看起来像一棵树。
我实际上使用了嵌套无序列表 (< ul >< li >),但这应该无关紧要。
现在,这只是展示。如果您需要交互性,您可能需要实现几个树行走算法并在子节点中保留对父节点的引用(这有很大帮助)。
关于javascript - 使用 JSON 数据的 HTML TreeMap ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18393010/
初学者 android 问题。好的,我已经成功写入文件。例如。 //获取文件名 String filename = getResources().getString(R.string.filename
我已经将相同的图像保存到/data/data/mypackage/img/中,现在我想显示这个全屏,我曾尝试使用 ACTION_VIEW 来显示 android 标准程序,但它不是从/data/dat
我正在使用Xcode 9,Swift 4。 我正在尝试使用以下代码从URL在ImageView中显示图像: func getImageFromUrl(sourceUrl: String) -> UII
我的 Ubuntu 安装 genymotion 有问题。主要是我无法调试我的数据库,因为通过 eclipse 中的 DBMS 和 shell 中的 adb 我无法查看/data/文件夹的内容。没有显示
我正在尝试用 PHP 发布一些 JSON 数据。但是出了点问题。 这是我的 html -- {% for x in sets %}
我观察到两种方法的结果不同。为什么是这样?我知道 lm 上发生了什么,但无法弄清楚 tslm 上发生了什么。 > library(forecast) > set.seed(2) > tts lm(t
我不确定为什么会这样!我有一个由 spring data elasticsearch 和 spring data jpa 使用的类,但是当我尝试运行我的应用程序时出现错误。 Error creatin
在 this vega 图表,如果我下载并转换 flare-dependencies.json使用以下 jq 到 csv命令, jq -r '(map(keys) | add | unique) as
我正在提交一个项目,我必须在其中创建一个带有表的 mysql 数据库。一切都在我这边进行,所以我只想检查如何将我所有的压缩文件发送给使用不同计算机的人。基本上,我如何为另一台计算机创建我的数据库文件,
我有一个应用程序可以将文本文件写入内部存储。我想仔细看看我的电脑。 我运行了 Toast.makeText 来显示路径,它说:/数据/数据/我的包 但是当我转到 Android Studio 的 An
我喜欢使用 Genymotion 模拟器以如此出色的速度加载 Android。它有非常好的速度,但仍然有一些不稳定的性能。 如何从 Eclipse 中的文件资源管理器访问 Genymotion 模拟器
我需要更改 Silverlight 中文本框的格式。数据通过 MVVM 绑定(bind)。 例如,有一个 int 属性,我将 1 添加到 setter 中的值并调用 OnPropertyChanged
我想向 Youtube Data API 提出请求,但我不需要访问任何用户信息。我只想浏览公共(public)视频并根据搜索词显示视频。 我可以在未经授权的情况下这样做吗? 最佳答案 YouTube
我已经设置了一个 Twilio 应用程序,我想向人们发送更新,但我不想回复单个文本。我只是想让他们在有问题时打电话。我一切正常,但我想在发送文本时显示传入文本,以确保我不会错过任何问题。我正在使用 p
我有一个带有表单的网站(目前它是纯 HTML,但我们正在切换到 JQuery)。流程是这样的: 接受用户的输入 --- 5 个整数 通过 REST 调用网络服务 在服务器端运行一些计算...并生成一个
假设我们有一个名为 configuration.js 的文件,当我们查看内部时,我们会看到: 'use strict'; var profile = { "project": "%Projec
这部分是对 Previous Question 的扩展我的: 我现在可以从我的 CI Controller 成功返回 JSON 数据,它返回: {"results":[{"id":"1","Sourc
有什么有效的方法可以删除 ios 中 CBL 的所有文档存储?我对此有疑问,或者,如果有人知道如何从本质上使该应用程序像刚刚安装一样,那也会非常有帮助。我们正在努力确保我们的注销实际上将应用程序设置为
我有一个 Rails 应用程序,它与其他 Rails 应用程序通信以进行数据插入。我使用 jQuery $.post 方法进行数据插入。对于插入,我的其他 Rails 应用程序显示 200 OK。但在
我正在为服务于发布请求的 API 调用运行单元测试。我正在传递请求正文,并且必须将响应作为帐户数据返回。但我只收到断言错误 注意:数据是从 Azure 中获取的 spec.js const accou
我是一名优秀的程序员,十分优秀!