我可以使用从我的目录中写入的 JSON 文件来初始化我的图表。但是,我很难尝试实现对我的 index.html(包含图表)所做的所有更改都将被保存和持久化的系统。最终目标是即使刷新 index.html 也能存储相同的数据 + 节点。
在这方面,我可以听到update
、和事件,但我不知道一旦这些事件被触发create
,我该怎么做。我应该能够使用从这些事件中接收到的参数直接编辑我的本地 JSON 文件。到目前为止,我可以获得参数,但我不知道如何使用这些新参数更新我的 JSON 文件。在这方面的任何想法都将受到高度赞赏。remove
delete
这是我的代码看起来很远的样子。除了使节点+数据持久化之外,它可以完成我想要的一切。
getOrgChart.themes.myCustomTheme = {
size: [270, 400],
toolbarHeight: 46,
textPoints: [{
x: 130,
y: 50,
width: 250
},
{
x: 130,
y: 90,
width: 250
}
],
textPointsNoImage: [{
x: 130,
y: 50,
width: 250
},
{
x: 130,
y: 90,
width: 250
}
],
expandCollapseBtnRadius: 20,
defs: '<filter id="f1" x="0" y="0" width="200%" height="200%"><feOffset result="offOut" in="SourceAlpha" dx="5" dy="5" /><feGaussianBlur result="blurOut" in="offOut" stdDeviation="5" /><feBlend in="SourceGraphic" in2="blurOut" mode="normal" /></filter>',
box: '<rect x="0" y="0" height="400" width="270" rx="10" ry="10" class="myCustomTheme-box" filter="url(#f1)" />',
text: '<text text-anchor="middle" width="[width]" class="get-text get-text-[index]" x="[x]" y="[y]">[text]</text>',
image: '<clipPath id="getMonicaClip"><circle cx="135" cy="255" r="85" /></clipPath><image preserveAspectRatio="xMidYMid slice" clip-path="url(#getMonicaClip)" xlink:href="[href]" x="50" y="150" height="190" width="170"/>',
reporters: '<circle cx="80" cy="190" r="20" class="reporters"></circle><text class="reporters-text" text-anchor="middle" width="100" x="80" y="195">[reporters]</text>'
//ddddd: '<text x="0" y="0">1</text>'
};
$.getJSON("http://localhost:8000/data.json", function(source) {
var peopleElement = document.getElementById("people");
var orgChart = new getOrgChart(peopleElement, {
photoFields: ["Image"],
linkType: "M",
enableEdit: true,
enableDetailsView: false,
theme: "myCustomTheme",
enableGridView: true,
primaryFields: ["Name", "Title", "Phone", "Address"],
enablePrint: true,
updateNodeEvent: wo,
renderNodeEvent: renderNodHandler,
dataSource: source
});
});
function wo(sender, args) {
n = args.node.data.Name
alert(n)
}
function renderNodHandler(sender, args) {
for (var i = 0; i < args.content.length; i++) {
if (args.content[i].indexOf("[reporters]") != -1) {
args.content[i] = args.content[i].replace("[reporters]", args.node.children.length);
}
}
}
html,
body {
margin: 0px;
padding: 0px;
width: 100%;
height: 100%;
overflow: hidden;
}
#people {
width: 100%;
height: 100%;
}
.get-text {
fill: #686868 !important;
}
.myCustomTheme-box {
fill: #FFFFFF;
stroke: #DDDAB9;
}
.reporters {
fill: #0072C6;
}
.reporters-text {
fill: #ffffff;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="opendb.js"></script>
<script src="getorgchart.js"></script>
<div id="content">
<div id="people"></div>
</div>