位置: 编程技术 - 正文

JS组件系列之Gojs组件 前端图形化插件之利器(js组件是什么)

编辑:rootadmin

推荐整理分享JS组件系列之Gojs组件 前端图形化插件之利器(js组件是什么),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript go,javascript go,js表格组件,js组件封装,js组件开发教程,js开发组件,组件中js可以做什么,组件中js可以做什么,内容如对您有帮助,希望把文章链接给更多的朋友!

前言:之前分享过两篇关于流程画图的前端组件,使用的jsPlumb。这个组件本身还不错,使用方便、入门简单、轻量级,但是使用一段时间下来,发现一些弊病,比如组件不太稳定,初始进入页面的时候连线的样式有时会乱掉,刷新页面之后才能恢复正常,而且连线样式比较单一,容易让人产生视觉疲劳,加之最近公司在大力推行所谓的“工业4.0”,除了对自动化控制要求的提高之外,对这种图形化界面的要求也随之提高,所以单纯的jsPlumb组件效果已经不能满足日益发展的公司业务。基于以上种种,最终找到了Gojs组件,它效果强大、api丰富,唯一的不足就是这个组件是一个收费组件,可是在天朝,嘘...这是个不能说的秘密!

本文原创地址: Canvas元素或SVG,也不用服务器端请求。 GoJS不依赖于任何JS库或框架(例如bootstrap、jquery等),可与任何HTML或JS框架配合工作,甚至可以不用框架。

2、使用入门

(1)文件引用

可以用cdn上面的最新版本,也可以引用本地down下来的文件。如果是开发,可以引用debug版本的js,正式运行的时候引用正式的js,这个无需多讲。

(2)创建画布

随便定义一个html元素,作为我们的画布

然后使用gojs的api初始化画布

官方示例用的$符号作为变量,博主觉得$符号太敏感,还是换个名字吧~以上几个参数都是博主摘选的,更多初始化画布的参数请参考官方api下图:

(3)创建模型数据(Model)

接着上面的代码,我们增加如下几行

效果预览

(4)创建节点(Node)

上面有了画布和节点数据,只是有了一个雏形,但是还没有任何的图形化效果。我们加入一些效果试试

在gojs里面给我们提供了几种模型节点的可选项:

Shape:形状——Rectangle(矩形)、RoundedRectangle(圆角矩形),Ellipse(椭圆形),Triangle(三角形),Diamond(菱形),Circle(圆形)等TextBlock:文本域(可编辑)Picture:图片Panel:容器来保存其他Node的集合 默认的节点模型代码只是由一个TextBlock组件构建成

我们增加如下一段代码

代码释疑:以上我们给画布对象定义了两种节点模板,一种是文本节点,另一种是形状节点(Node)。在形状节点中,我们定义了数据模型的通用节点样式,就是这一段代码{ /* Shape的参数。宽高颜色等等*/figure: "Club", width: , height: , margin: 4, fill: 'red' },然后通过new go.Binding("figure", "fig")方法将模板里面的属性映射到数据实例中,比如这里模板里面的figure属性定义的是Club,如果在我们的数据里面定义fig属性,那么它就会覆盖模板里面的figure的默认值。同样,fill和fill2也是通过同样的原理去区别模板中的样式和实例中的实际样式的!

JS组件系列之Gojs组件 前端图形化插件之利器(js组件是什么)

注:更多figure属性的取值详见这里

效果如下

由此可见我们数据里面的属性会覆盖模板的原始属性,如果是新增的节点,由于没有自定义数据属性,所以呈现到界面上面的时候就是模板里面的原生样式!

(5)节点连线

有了上面的基础,我们可以在画布上面画出我们想要的图形效果了,可是还没有连线。我们知道连线是建立在节点模型的上面的,于是乎我们的Model又分为了以下三种类型:

Model:最基本的(不带连线,如上面的例子)

GraphLinksModel :高级点的动态连线图

TreeModel:树形图的模型(从例子看好像用的不多)

GraphLinksModel中为model.nodeDataArray提供model.linkDataArray为node节点连线保存数据模型信息,其实也是的一个JSON数组对象,每个线条都有两个属性 “to” 和 “from” 即Node节点的“key”值,两个属性代表两个key表示两个节点间的连线。

我们上面已经写过最基本的Model的例子了,我们再来个带连线的Model的示例

效果如下

学习了Model、GraphLinksModel,还剩下一种TreeModel树节点的模型,这个博主不打算做详细介绍,有兴趣可以直接查看官网。

三、综合效果

关于综合效果,博主不打算将gojs的api逐个翻个遍了,这样太耗时间,伤不起,只是将官方示例中的部分源码截取出来供大家参考。有需要的再细究!

1、自定义流程的使用

效果如下:

建议各位copy代码,在本地看到效果,然后再根据实际需求去研究它的api,这样才不会太盲目而花费太多时间。

2、工业流程图

工业流程图

四、总结

本文根据js的一些基础用法做了简单介绍,今天就先到这里,以后有问题了再来跟大家分享。如果你的项目里面也有这种业务需求,可以用起来试试!需要说明一点,如果您的公司不缺钱,建议使用正版授权的组件,毕竟尊重作者的劳动成果很重要!

标签: js组件是什么

本文链接地址:https://www.jiuchutong.com/biancheng/373291.html 转载请保留说明!

上一篇:ReactNative之FlatList的具体使用方法

下一篇:微信小程序使用modal组件弹出对话框功能示例(微信小程序使用webview)

  • 税控盘抵扣税款
  • 甲供材料的增值税是多少
  • 村委会什么会计准则
  • 税款必须要15号之前交吗
  • 公司名称变更期间可以投标吗
  • 国税地税电子钥匙价格
  • 购进库存商品到销售全部分录
  • 缴纳个税和社保
  • 预缴企业所得税会计处理
  • 住房公积金证书插上为什么登不进去
  • 民事诉讼的适用范围具体包括哪些案件
  • 补缴企业所得税滞纳金账务处理
  • 限售股所得税的优惠政策
  • 采购比价流程图
  • 公司一般根据什么裁员
  • 企业所得税一般是几个点
  • 投资税收抵免
  • 以前年度少计收入 会计怎么处理
  • 银行转账备用金是什么意思
  • 年初未交增值税借方怎么处理
  • 研发过程中材料费计入
  • 客户分批付款怎么说
  • 在建工程如何评估价值
  • 吸收合并公司后的债务处理
  • 新装的电脑开机慢是什么原因
  • 工会经费是否可以给非会员使用
  • 赠与合同要公证吗有效吗
  • 台湾中原大学相当于大陆几本
  • 未计发放待遇
  • php怎么学
  • 销售需要安装的商品,只能在安装和检验完毕后确认收入
  • 骑自行车的好处功效与作用
  • 克卢恩国家公园在哪里
  • 纳税人临时到外省从事经营活动
  • php获取指定日期的时间戳
  • thinkphp5教程
  • 反射dll
  • js遇到的问题
  • 增值税的滞纳金税率
  • (WebFlux)004、WebFilter踩坑记录
  • python根据键输出值
  • 出口退税超期了怎么办
  • php7编译安装gd库
  • 增值税扣税凭证不包括
  • 供热管道属于什么结构类型
  • 小规模纳税人可以开13的税吗
  • 在建工程的土地可以查封吗
  • 应交税费明细科目设置最新
  • 产假工资扣税
  • 资产减少的方式有哪些?
  • 母子公司可以合并吗
  • 企业代办业务有哪些
  • 赠送给客户的产品怎么做账
  • 客户赔款会计科目
  • 赠送成本的会计分录
  • 微信转账报销怎么退回
  • 商业企业库存商品
  • Windows server 2008设置远程桌面连接的详细步骤(图文教程)
  • win7系统怎样设置
  • win8怎样关闭系统更新
  • macoshosts文件位置
  • windows7装进u盘
  • win7系统怎么设置桌面便签
  • 2016年Win10 Mobile红石更新抢先看 预期新功能/发布时间表
  • cocos 2d x
  • 用于播放html5视频文件的正确
  • perl使用保留字引用什么模块
  • cocos2dx游戏开发
  • js类继承的几种方式
  • jquery操作html代码
  • 安卓开发问题
  • python做应用软件界面
  • Javascript & DHTML 实例编程(教程)(四)初级实例篇2—动画
  • 以下关于android应用程序的目录结构描述中,不正确的是
  • 海南税务局增值税按次缴纳
  • 北京市地方税务局发票查验
  • 装卸搬运服务是什么服务
  • 违法的税务记录怎么消除
  • 打税务局电话
  • 2022年印花税最新规定反映了什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设