脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|shell|

服务器之家 - 脚本之家 - Golang - GoJs基本使用示例详解

GoJs基本使用示例详解

2023-04-16 17:10沅芷湘兰 Golang

这篇文章主要为大家介绍了GoJs基本使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

使用gojs背景

因为公司业务需要,需要完成一个树形的关系图,并且在后续过程中会对树形关系图进行很多的交互来拓展树形图的展示。因此在研究了D3,antV G6,cytoscape和go.js之后,决定使用gojs实现。因为gojs的交互功能封装比较完善,能够很快的搭建出想要的关系图之外,还有很多封装好的交互功能。例如可以使用键盘进行节点的复制和粘贴,通过textEdited属性实现节点内文字的双击编辑等等。

gojs的引入

我们可以直接引入js的方法对gojs进行引入

?
1
<script src="go.min.js"></script>

还可以使用cdn的方式进行使用

?
1
<script src="https://unpkg.com/gojs/release/go-debug.js"></script>

当然也可以通过npm进行安装

?
1
npm install gojs --save

本文档以引入gojs文件的方式,在vue中使用为例。因此我是在index中引入了gojs文件,因为方便去除水印,并且代码的同步。

然后我们就可以gojs进行使用啦,首先我们需要在使用的页面进行引入。

?
1
2
3
<script>
let $$ = go.GraphObject.make;//因为项目中使用到jquery,所以使用$$进行一个区分
export default {

然后在mounted中对this进行一个接收,以便我们在使用的时候出现this指向错误的问题。

?
1
2
3
4
5
6
mounted(){
    let _this = this
    this.$nextTick(()=>{
       this.init();//gojs实例化方法
    })
}

和很多可视化框架一样,我们首先要为我们的图形渲染提供一个容器,

?
1
2
3
4
5
<div
    id="myDiagramDiv"
    style="width:300px;
    height:300px;">
</div>

然后我们对gojs进行实例化,通过容器的id进行绑定,并且为图形的布局方式设置一个树形布局。

?
1
2
3
4
5
init(){
    this.myDiagram = $$(go.Diagram, "myDiagramDiv",{
    layout: $$(go.TreeLayout)//布局方式,TreeLayout为树形布局
    });
}

这样,我们一个简单的画布就已经初始化完成了。然后我们在画布中加入一些相数据

?
1
2
3
4
5
6
7
8
9
10
this.myDiagram.model = new go.Model(
  [
    { key: "1" },
    { key: "1-1" },
    { key: "1-2" }
  ],
  [
    {form:"1",to:"1-1"},
    {form:"1",to:"1-2"},
  ]);

然后一个简单的树形布局的图形就出来了

GoJs基本使用示例详解

在执行new go.Model的时候,其传入的两个参数分别为节点数据和连线数据,在这里我们称之为nodes和links,其中nodes中包括key(必须,节点的唯一标识)和其他字段(主要是存储一些节点的配置项,比如节点的number数据或者其他需要在节点内显示的文字和图表等),而links包括from(必须,连线的出发节点的key)和to(必须,连线的结尾节点的key)字段和其他字段(比如连线上的关系文字说明),其中节点通过key来标识,因此我们要求数据的key必须唯一。不然的话,link数据在匹配出发节点和结束节点的会匹配到nodes数据中key值相同后面的节点,而nodes数据中key值相同的面的数据节点会生成一个游离的节点,因此不符合我们的需求。并且因为属性布局的特殊结构,我们还可以parent字段来处理一下数据。

?
1
2
3
4
5
6
this.myDiagram.model = new go.TreeModel(
    [ // the nodeDataArray
        { key: "1" },
        { key: "1-1", parent: "1" },
        { key: "1-2", parent: "1" }
    ]);

可以根据自己的实际需求进行选择性进行哪种方式渲染方式。

去除水印

当然你应该也发现了,图像渲染的画布上会出现gojs的版本信息和介绍等等水印,而去除这些水印是需要氪金的,然而我们还有一些其他方法能对水印进行去除,我们在下载的go.min.js中全局搜索7eba17a4ca3b1a8346找到a.ir或者a.jv等,因为版本的不一样属性的名字也会发生改变

?
1
a.ir=b.W[Ra("7eba17a4ca3b1a8346")][Ra("78a118b7")](b.W,ok,4,4);

然后把这段代码替换为

?
1
a.ir=function(){return true;};

只要保证属性名一致就可以,然后重启我们的项目就可以清除水印啦。

在下篇文章中我们会通过this.myDiagram.nodeTemplate中的通过TextBlock、shape、Picture、Groups、Panel和界面的布局来对我们的节点进行丰富而显示出各种各样并且显示内容不同的的节点类型。

以上就是GoJs基本使用示例详解的详细内容,更多关于GoJs基本使用的资料请关注服务器之家其它相关文章!

原文链接:https://juejin.cn/post/7220396447463718968

延伸 · 阅读

精彩推荐
  • Golanggoland 清除所有的默认设置操作

    goland 清除所有的默认设置操作

    这篇文章主要介绍了goland 清除所有的默认设置操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    limo19967162021-06-05
  • GolangGo语言中字符串的查找方法小结

    Go语言中字符串的查找方法小结

    这篇文章主要介绍了Go语言中字符串的查找方法小结,示例的main函数都是导入strings包然后使用其中的方法,需要的朋友可以参考下 ...

    脚本之家14462020-04-27
  • GolangGo语言map字典用法实例分析

    Go语言map字典用法实例分析

    这篇文章主要介绍了Go语言map字典用法,实例分析了map字典的使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下 ...

    秋风秋雨6052020-04-19
  • Golanggolang-gin-mgo高并发服务器搭建教程

    golang-gin-mgo高并发服务器搭建教程

    这篇文章主要介绍了golang-gin-mgo高并发服务器搭建教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    wayne_鱼蛋12662021-03-05
  • Golang详解Golang中下划线的使用方法

    详解Golang中下划线的使用方法

    这篇文章主要介绍了详解Golang中下划线的使用方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 ...

    happen3892020-05-22
  • Golanggolang gorm开发架构及写插件示例

    golang gorm开发架构及写插件示例

    这篇文章主要为大家介绍了golang gorm开发架构及写插件的详细示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪...

    Jeff的技术栈5242022-09-21
  • GolangGo语言学习之运算符使用详解

    Go语言学习之运算符使用详解

    这篇文章主要介绍了Go语言中常用运算符的使用,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...

    剑客阿良_ALiang12062022-09-14
  • Golanggoland设置颜色和字体的操作

    goland设置颜色和字体的操作

    这篇文章主要介绍了goland设置颜色和字体的操作方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    igoodful5432021-06-18