gojs常用API-画布操作
画布
| 获取当前画布的json | myDiagram.model.toJson(); |
| 加载json刷新画布 | myDiagram.model = go.Model.fromJson(model); |
| 删除选中节点或线 | myDiagram.commandHandler.deleteSelection(); |
|
获取选中的节点或线 myDiagram.selection |
|
|
获取画布所有节点对象 myDiagram.nodes |
|
节点
| 添加节点 | myDiagram.model.addNodeData(nodeData); |
| 删除节点 | myDiagram.model.removeNodeData(nodeData); |
| 选中单个节点(不能批量选中) | myDiagram.select(node); |
| 更改属性值 | myDiagram.model.setDataProperty(nodeData, 'color', "#ededed"); |
|
根据节点数据对象 更改节点属性 myDiagram.model.updateTargetBindings(nodeData); |
|
| 获取节点对象 | var node=myDiagram.findNodeForKey('key'); |
| 获取节点data | var nodeData=myDiagram.model.findNodeDataForKey('key'); |
|
批量删除节点 myDiagram.model.removeNodeDataCollection(nodes) |
|
|
模糊获取节点(版本1.68以上) 注意值类型,字符串和数值 myDiagram.findNodesByExample(data); 匹配方式默认为===运算符进行比较。 /abc/ 匹配包含“abc”的任何字符串 官网还有更多的匹配方式,这里就不列举了 |
|
线
| 添加线 | myDiagram.model.addLinkData(linkData); |
| 删除线 | myDiagram.model.removeLinkData(linkData); |
|
批量删除线 {Array|iterator} removeLinks removeLinkDataCollection(removeLinks); |
|
|
模糊获取线(版本1.68以上) 注意值类型,字符串和数值 myDiagram.findLinksByExample(data); 匹配 方式和模糊获取节点的规则一致 |
|
| 更改属性值 | myDiagram.model.setDataProperty(linkData, 'from', "-2"); |
|
获取节点的线 {string | null =} PID 端口ID findLinksConnected(PID) |
var node=myDiagram.findNodeForKey('key'); node.findLinksConnected().each(function(link) {console.log(link.data)}); |
|
获取进入节点的线 {string | null =} PID 端口ID findLinksInto(PID) |
var node=myDiagram.findNodeForKey('key'); node.findLinksInto().each(function(link) {console.log(link.data)}); |
|
获取从节点出来的线 {string | null =} PID 端口ID findLinksOutOf(PID) |
var node=myDiagram.findNodeForKey('key'); node.findLinksOutOf().each(function(link) {console.log(link.data)}); |
|
获取A-B节点之间的线 findLinksTo(othernode, PID, otherPID) |
var nodeA=myDiagram.findNodeForKey('key'); var nodeB=myDiagram.findNodeForKey('key'); nodeA.findLinksTo(nodeB).each(function(link) {console.log(link.data)}); |
树节点
|
根据甲,找甲的祖宗十八代(包括甲) node.findTreeParentChain(); |
|
|
根据甲,找甲的子孙十八代(包括甲) node.findTreeParts(); |
|
|
根据甲,找甲的父亲 node.findTreeParentNode(); |
var pNode=node.findTreeParentNode(); |
|
根据甲,找甲的孩子们 node.findTreeChildrenNodes(); |
|
|
根据甲,获取甲和其孩子的关系 node.findTreeChildrenLinks(); |
未测 |
gojs操作画布常用API
| API | 用例 | |
|---|---|---|
| 增 |
addNodeData(节点对象); addLinkData(线对象); |
|
| 删 |
removeNodeData(节点对象) removeLinkData(线对象); |
|
| 改 |
参数: data: nodeData或linkData propname:属性名 val:修改的值 setDataProperty(data, propname, val); |
|
| 查 |
根据key获取节点data对象 findNodeDataForKey('节点key'); 根据linkData模糊匹配线集合 (gojs1.68以上) findLinksByExample(linkData) |
|
gojs 函数实践
1、添加节点
- var CreateNode={
- key:getNextKey(), //设置key的方法,每个节点最好是有自己独立的key
- "category":"nodeStyleOne", //节点样式选择?nodeStyleOne? => 你自己定义的样式名
- "loc":"",
- "text":"节点的text值",//也阔以是动态的值
- source:“123.svg”,//也阔以是动态的路径
- }
- myDiagram.model.addNodeData(CreateNode);
2、动态加线
myDiagram.model.addLinkData({"from":连线起点的key, "to":连线终点key,"category":样式名});
gojs最佳教程: http://www.devtalking.com/categories/%E5%89%8D%E7%AB%AF/
https://liuxiaofan.com/2018/03/16/3521.html
https://www.jianshu.com/p/f91fbf085574
http://www.aubreyling.com/category/javascript/gojs/
参考以上考程,能基本上把gojs弄懂
gojs常用API-画布操作的更多相关文章
- gojs常用API (中文文档)
常用API 操作类API API 例子 应用场景 添加节点 myDiagram.model.addNodeData(node); var node = {}; node["key&q ...
- gojs常用API
操作类API: 添加节点: myDiagram.model.addNodeData(node); var node = {}; node["key"] = "节点Key& ...
- Java常用api和操作必背
1.数组排序 Java的Arrays类(java.util中)包含用来操作数组(比如排序和搜索)的各种方法. Arrays.sort(各种类型数组) 2.数组转字符串 1)打印数组时可用Arrays. ...
- Java学习笔记五 常用API对象一
常用API:字符串操作:String类,StringBuffer类,StringBulider类 字符串是最重要的数据类型之一,处理字符串也是一种语言的基本工作. 1.String类: public ...
- Javascript操作DOM常用API总结
基本概念 在讲解操作DOM的api之前,首先我们来复习一下一些基本概念,这些概念是掌握api的关键,必须理解它们. Node类型 DOM1级定义了一个Node接口,该接口由DOM中所有节点类型实现.这 ...
- node.js整理 02文件操作-常用API
NodeJS不仅能做网络编程,而且能够操作文件. 拷贝 小文件拷贝 var fs = require('fs'); function copy(src, dst) { fs.writeFileSync ...
- JS操作DOM常用API总结
<JS高程>中的DOM部分写的有些繁琐,还没勇气整理,直到看到了这篇博文 Javascript操作DOM常用API总结,顿时有了一种居高临下,一览全局的感觉.不过有时间还是得自己把书里面的 ...
- JavaScript 操作 DOM 常用 API 总结
文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认识. 基本概念 在讲解操作DOM的api之前, ...
- [总结]JS操作DOM常用API详解
文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认识. 基本概念 在讲解操作DOM的api之前, ...
随机推荐
- RootKit随手记(一)RootKit的驱动隐藏、读取配置、卸载安装
边学习边更新这专题,随手记录一下用到的思路,给自己看的(所以读者看可能有些懵,不好意思...) RootKit随手记(一)RootKit的驱动隐藏.读取配置.卸载安装 一.驱动隐藏 1. 隐藏原理 一 ...
- 2019-11-25-如何在国内发布-UWP-应用
原文:2019-11-25-如何在国内发布-UWP-应用 title author date CreateTime categories 如何在国内发布 UWP 应用 lindexi 2019-11- ...
- ASP.NET Core快速入门(第1章:介绍与引入)--学习笔记
课程链接:http://video.jessetalk.cn/course/explore 良心课程,大家一起来学习哈! 任务1:课程介绍 1.介绍与引入 2.配置管理 3.依赖注入 4.ASP.NE ...
- 【UWP】实现 FindAncestor 绑定
在 WPF 里,我们是可以在 RelativeSource 上面实现的,举个例子: <Grid Tag="2"> <Button> <Grid Tag ...
- Python - 输入和输出 - 第十七天
Python 输入和输出 在前面几个章节中,我们其实已经接触了 Python 的输入输出的功能.本章节我们将具体介绍 Python 的输入输出. 输出格式美化 Python两种输出值的方式: 表达式语 ...
- IP 跟踪
#coding=utf-8import sysimport os import re import urllibimport subprocess def getlocation(ip): resul ...
- 第四篇Scrum冲刺博客
第四篇Scrum冲刺博客 一.站立式会议 提供当天站立式会议照片一张 二.每个人的工作 成员 已完成工作 明天计划完成的工作 遇到的困难 林剑峰 用户界面跳转到用户信息页面的按钮,设计用户信息页面 测 ...
- du查看某个文件或目录占用磁盘空间的大小
一.du的功能:`du` reports the amount of disk space used by the specified files and for each subdirectory ...
- JDBC及C3P0常用类
JDBC(Java Database Connectivity)JAVA数据库连接,它是一套用于执行SQL语句的Java API.JDBC可以通过不同驱动与不同数据库连接,相当于JAVA和数据库之间的 ...
- ajax的一些知识
一.关于XMLHttpRequest的实例的属性和方法 实例的属性: 1.xhr.response 响应主体内容 2.xhr.responseText 响应主体内容字符串(JSON或者XML格式字符串 ...