使用gojs画出拓扑图,清晰的看出组织人员关系

GoJS 是一个使用 HTML5, SVG 和 JavaScript 构建的图表库,可以用来创建和编辑交互式图表。以下是一个简单的例子,展示如何使用 GoJS 在 GoJS 的模板中创建一个简单的拓扑图。

首先,你需要在你的 HTML 文件中引入 GoJS:




<script src="https://gojs.net/latest/api/go-debug.js" type="text/javascript"></script>

然后,你可以使用以下的 JavaScript 代码来创建一个拓扑图:




function init() {
  // 创建一个 GoJS 图表
  const $ = go.GraphObject.make;  // 创建图表对象的快捷方式
  const myDiagram = $(go.Diagram, "myDiagramDiv");  // 指定图表的 DOM 容器
 
  // 设置图表的模板和属性
  myDiagram.nodeTemplate =
    $(go.Node, "Auto",
      $(go.Shape, "RoundedRectangle", {
        fill: "white", // 节点形状的填充颜色
        strokeWidth: 1, // 节点形状的边框宽度
        portId: "", // 节点的端口名称
        fromLinkable: true, // 是否可以从此节点连接出线
        toLinkable: true // 是否可以连接到此节点的线
      }),
      $(go.TextBlock, { margin: 7, editable: true }, // 文本块,可编辑
        new go.Binding("text")) // 文本绑定到节点的名称属性
    );
 
  myDiagram.linkTemplate =
    $(go.Link,
      { routing: go.Link.Orthogonal, // 线条的路由方式
        corner: 5, // 线条弯曲的角度
        selectionAdornmentTemplate: $(go.Adornment, "Link",
          $(go.Shape, { stroke: "blue", strokeWidth: 2, fill: null }))
      },
      $(go.Shape, { strokeWidth: 1.5, stroke: "#000" }), // 线条的形状和颜色
      $(go.TextBlock, { margin: 20 }, // 文本块
        new go.Binding("text", "text")) // 文本绑定到线条的文本属性
    );
 
  // 向图表中添加节点和连接线
  myDiagram.model = new go.GraphLinksModel(
    [
      { key: "Alpha", text: "Alpha" },
      { key: "Beta", text: "Beta" },
      { key: "Gamma", text: "Gamma" }
    ],
    [
      { from: "Alpha", to: "Beta" },
      { from: "Alpha", to: "Gamma" }
    ]
  );
}

在 HTML 文件中,你需要有一个用于显示图表的容器:




<div id="myDiagramDiv" style="width:500px; height:350px; background-color: #DAE4E0;"></div>
<script>
  window.onload = init;
</script>

这个简单的例子创建了一个包含三个节点和两条连接线的拓扑图。你可以根据需要添加更多的节点和连接。GoJS 提供了丰富的功能和自定义选项,可以用来创建各种复杂的图表和可视化。

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日