五分钟搞定Go.js 

1、基于html5~因为Go.js是一个依赖于HTML5特性的JavaScript库,所以需要确保您的页面声明它是一个HTML5文档,当然需要加载库

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="description" content="An organization chart editor -- edit details and change relationships." />
<title>数据图形化</title>
<script src="js/go.js"></script>
</head>

2、每个Go.js图都包含在HHTML元素中,我们需要给出一个显示的大小

<div id="myDiagramDiv"
style="width:400px; height:150px; background-color: #DAE4E4;"></div>

3、在JavaScript代码中,绘制图表时需要传递ID

var $ = go.GraphObject.make;
var myDiagram = $(go.Diagram, "myDiagramDiv");

注意:go是所有Gojs类型的“名称空间”。所有使用GoJs类的代码,如图表、节点、面板、形状或文本块,都以go做为前缀。

make来构建Gojs对象,使用$作为go.GraphObject的缩写。图中的加点和链接是由模型管理数据的可视化表示。GoJs有一个模型视图系统结构,其中模型包含描述节点和链接的数据(JavaScript对象数组)

基础图例代码

var $ = go.GraphObject.make;
var myDiagram = $(go.Diagram, "myDiagramDiv",
{
"undoManager.isEnabled": true // enable Ctrl-Z to undo and Ctrl-Y to redo
});
var myModel = $(go.Model);
// in the model data, each node is represented by a JavaScript object:
myModel.nodeDataArray = [
{ key: "Alpha" },
{ key: "Beta" },
{ key: "Gamma" }
];
myDiagram.model = myModel;

简单介绍下以下几个小功能:

()在上图中单击并拖动背景以平移视图
()单击一个节点来选择它,或者按下并拖动一个节点来移动它
()要创建一个选择框,单击并按住背景,然后开始拖动
()使用CTRL-C和CTRL-V,或control-drag- drop,创建选择的副本
()按Delete键删除选中的节点。(阅读更多键盘命令。)
()由于启用了撤消管理器,CTRL-Z和CTRL-Y将撤消和重做移动、复制和删除操作。

4、一些属性的使用:

“shape”:用颜色显示预先定义或自定义的几何图形

“TextBlock”以各种字体显示(可编辑文本)

“Picture”用来显示图片

“Panel(面板)”,用来存放其他对象集合的容器,这些对象可以根据面板的类型以不同的方式惊醒定位和大小调整(如垂直堆栈和拉伸容器)

所有这些构建块都来自于GraphObject抽象类,因此我们随意地将它们称为GraphObject、对象或元素。注意,GraphObject不是HTML DOM元素,因此在创建或修改方面没有太多开销

我们希望模型数据属性影响我们的节点,这是通过数据绑定实现的。数据绑定允许我们通过自动设置这些GraphObjects的属性值来更改节点中的GraphObjects的外观和行为
使用介绍:
默认的节点模板很简单:一个包含一个文本块的节点。文本块的文本属性和模型数据的键属性之间有数据绑定。在代码中,模板看起来是这样的:
myDiagram.nodeTemplate =
$(go.Node,
$(go.TextBlock,
// TextBlock.text is bound to Node.data.key
new go.Binding("text", "key"))
); 注意:文本块、形状和图片是GoJS的原始构建块。文本块不能包含图像;形状不能包含文本。如果想让节点显示一些文本,必须使用文本块。

5、

创建简单的图形面板
一种“水平”面板类型的节点,意味着其元素将被水平并排地放置。它有两个要素:
(1)一个图片为肖像,与图像源数据绑定
(2)带有文本数据绑定的名称文本块

6、

可以设置默认显示的内容
我们可能希望在不是所有信息都存在的情况下显示一些“默认”状态,例如当图像不加载或不知道名称时。本例中的“空”节点数据用于显示节点模板在没有值的情况下可以很好地工作

7、

使用自定义节点模板,
我们的关系图变得非常漂亮,但是我们可能想要展示更多。也许我们需要一张组织结构图来证明唐·喵真的是一个猫卡特尔的老板。所以我们将创建一个完整的组织结构图
为了让链接进入我们的图表,基本模型不会削减它。我们将不得不在GoJS中选择另外两个模型中的一个,这两个模型都支持链接。这些是GraphLinksModel和TreeModel。(请阅读更多关于模型的内容。)

8、

树模板的使用
树模有点不同。树模型中的链接不是维护单独的链接数据数组,而是通过为节点数据指定“父”来创建的。然后从这个关联创建链接。这里有一个和Tr相同的例子

9、

图的布局
图有一个默认布局,它接受所有没有位置的节点,并给它们位置,将它们安排在网格中。我们可以显式地为每个节点提供一个位置,以解决组织混乱的问题
我们想要显示一个层次结构,并且已经在使用TreeModel,所以最自然的布局选择是TreeLayout。TreeLayout默认从左到右流动,所以为了让它从上到下流动(这在组织图中很常见)

大家自己可以尝试啦!!!!!!!!!!!

五分钟搞定Go.js的更多相关文章

  1. zookeeper-架构设计与角色分工-《每日五分钟搞定大数据》

    本篇文章阅读时间5分钟左右 点击看<每日五分钟搞定大数据>完整思维导图   zookeeper作为一个分布式协调系统,很多组件都会依赖它,那么此时它的可用性就非常重要了,那么保证可用性的同 ...

  2. zookeeper核心-zab协议-《每日五分钟搞定大数据》

    上篇文章<paxos与一致性>说到zab是在paxos的基础上做了重要的改造,解决了一系列的问题,这一篇我们就来说下这个zab. zab协议的全称是ZooKeeper Atomic Bro ...

  3. HDFS-异常大全-《每日五分钟搞定大数据》

    点击看<每日五分钟搞定大数据>完整思维导图以及所有文章目录 问题1:Decomminssioning退役datanode(即删除节点) 1.配置exclude: <name>d ...

  4. 五分钟搞定 HTTPS 配置,二哥手把手教

    01.关于 FreeSSL.cn FreeSSL.cn 是一个免费提供 HTTPS 证书申请.HTTPS 证书管理和 HTTPS 证书到期提醒服务的网站,旨在推进 HTTPS 证书的普及与应用,简化证 ...

  5. 五分钟搞定Linux容器

    [TechTarget中国原创] Linux容器针对特定工作负载提供了全新的灵活性与可能性.存在很多解决方案,但是没有一个解决方案能够像systemd容器那样进行快速部署.给我五分钟,本文将介绍如何使 ...

  6. 五分钟搞定Docker安装ElasticSearch

    前言 项目准备上ElasticSearch,为了后期开发不卡壳只能笨鸟先飞,在整个安装过程中遇到以下三个问题. Docker安装非常慢 ElasticSearch-Head连接出现跨域 Elastic ...

  7. 五分钟搞定 Linux 文档全部知识,就看这篇文章

    作者:无痴迷,不成功 来源:见文末 写在前面 我们都知道Linux是一个支持多用户.多任务的系统,这也是它最优秀的特性,即可能同时有很多人都在系统上进行工作,所以千万不要强制关机,同时,为了保护每个人 ...

  8. zookeeper-操作与应用场景-《每日五分钟搞定大数据》

    Zookeeper作为一个分布式协调系统提供了一项基本服务:分布式锁服务,分布式锁是分布式协调技术实现的核心内容.像配置管理.任务分发.组服务.分布式消息队列.分布式通知/协调等,这些应用实际上都是基 ...

  9. zookeeper-如何修改源码-《每日五分钟搞定大数据》

    本篇文章仅仅是起一个抛砖迎玉的作用,举一个如何修改源码的例子.文章的灵感来自 ZOOKEEPER-2784. 提一个问题先 之前的文章讲过zxid的设计,我们先复习下: zxid有64位,分成两部分: ...

随机推荐

  1. Java基于opencv—透视变换矫正图像

    很多时候我们拍摄的照片都会产生一点畸变的,就像下面的这张图 虽然不是很明显,但还是有一点畸变的,而我们要做的就是把它变成下面的这张图 效果看起来并不是很好,主要是四个顶点找的不准确,会有一些偏差,而且 ...

  2. NYOJ-15:括号匹配(二)

    内存限制:64MB 时间限制:1000ms 特判: No 通过数:54 提交数:158 难度:6 题目描述: 给你一个字符串,里面只包含"(",")",&quo ...

  3. PAT乙级考前总结(一)

    数学相关的题目 1001 害死人不偿命的(3n+1)猜想 (15 分) 直接一步步计数 1005 继续(3n+1)猜想 (25 分) 卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目 ...

  4. vue day7 table checkbox 全选

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  5. COOKIE和SESSION之间的区别以及用法

    一.Session简单介绍 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务 ...

  6. mybatis 中javaType和OfType 的区别

    JavaType和ofType都是用来指定对象类型的,但是JavaType是用来指定pojo中属性的类型,而ofType指定的是映射到list集合属性中pojo的类型.pojo类: publiccla ...

  7. Python基础测试题

    1,执行Python脚本的两种方式 答:一种是 交互式,命令行shell启动Python,输入相应代码得出结果,无保存,另一种是 脚本式,例如:python 脚本文件.py,脚本文件一直存在,可编辑, ...

  8. c++——智能指针学习(shared_ptr和weak_ptr)

    先看一个例子:Stark和Targaryen家族你中有我,我中有你.我们设计以下类企图避免内存泄漏,使得析构函数都能调用到: #include<iostream> #include< ...

  9. 宝塔linux面板 解决TP3.2 404

    在配置文件中加入一下配置: location / { if (!-e $request_filename) { rewrite ^/(.*)$ /index.php/$1; } } location ...

  10. 1.2.8 Excel做个滚动抽奖

    1.首先要准备好数据库: 2.用RAND函数来生成随机数字,做一个辅助列: 3.制作抽奖界面: 4.输入公式: 在F3中输入下列公式并填充至F5: =INDEX(A:A,MATCH(SMALL(B:B ...