2

我可以使用从我的目录中写入的 JSON 文件来初始化我的图表。但是,我很难尝试实现对我的 index.html(包含图表)所做的所有更改都将被保存和持久化的系统。最终目标是即使刷新 index.html 也能存储相同的数据 + 节点。

在这方面,我可以听到update、和事件,但我不知道一旦这些事件被触发create,我该怎么做。我应该能够使用从这些事件中接收到的参数直接编辑我的本地 JSON 文件。到目前为止,我可以获得参数,但我不知道如何使用这些新参数更新我的 JSON 文件。在这方面的任何想法都将受到高度赞赏。removedelete

这是我的代码看起来很远的样子。除了使节点+数据持久化之外,它可以完成我想要的一切。

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>

4

1 回答 1

0

好的,因为似乎没有人回答这个问题。我将自己回答这个问题以供将来参考。

好吧,所以我不得不创建后端来处理这个问题。具体来说,我安装了nodejs. 我使用express.jsandajax来发送/接收来自客户端和服务器的数据。使用getorgcharts文档中提供的事件,即insertNodeEventupdateNodeEvent等我实现了 CURD。在这方面,npm 库diskdb是救命稻草!json通过相对于客户端执行的 CURD 操作更改文件,使持久化成为可能。然后,服务器端代码将相应地添加/更新/编辑/删除json文件中的记录。

于 2017-09-22T19:30:27.457 回答