图表开发控件JointJS携全新4.0版本助力轻量开发

news/2024/5/18 17:38:44

JointJS 和JointJS+的v4.0版本正式发布,作为图表库的首个无依赖版本,备受期待!新版本经过精心打磨,摆脱了jQuery、Backbone和Lodash的依赖,使得库更加精简且核心功能不变。此次慧都与JointJS厂商合作,携手带来全新版本v4.0,欢迎大家前往咨询~

此次更新带来了众多改进,将在本篇博文中简要介绍。若您渴望深入了解所有技术细节,建议完整阅读更新日志。

JointJS 是一款基于 JavaScript 的开源库,用于创建基于 HTML5 的交互式图表和图形编辑器。它提供了丰富的图形元素和交互功能,支持用户构建复杂的流程图、组织结构图、网络拓扑图等,适用于开发各种 Web 应用程序。

JointJS免费下载icon-default.png?t=N7T8https://www.evget.com/product/4370/download

公司首席技术官Roman Brückner表示:“ v4.0版本标志着重要里程碑的达成。我们针对代码库中的反直觉部分以及对旧版库的依赖进行了改进,新版解决了这些问题。API的优化提高了上手速度,而外部依赖的消除则提升了性能,并让我们对库有了完全的控制权。”

重要提示:v4.0版本带来了重大变更。因此,JointJS+的客户应详细阅读从3.7到4.0的迁移指南,确保顺利过渡到最新版本。

稳定版本,无外部依赖

如前所述,现在引入了一个不依赖jQuery、Lodash和Backbone的无依赖版本。这一期待已久的改进使的库更加精简(减小了包大小,如下所示),并使能够完全控制核心功能,并根据客户的特定需求进行调整。 JointJS 和 JointJS+ 的可定制性水平是的骄傲之一,4.0 版本使(和您)能够在不做出任何妥协的情况下调整库:

  • 完全控制库:现在负责整个代码库,并完全负责并有能力修复客户报告的任何错误。同样的可能性也适用于的社区,这有助于改进的开源版本 JointJS。
  • 更精简且高性能:通过依赖为服务许多不同用例而构建的外部依赖项,在代码库中包含了许多不必要的功能。现在这种情况已经改变,提高了性能并使能够根据任何特定用例定制的库。
    重大升级,平滑迁移:保留了 90% 以上的 API 功能,并尽一切努力让您从以前的版本顺利迁移。尽管 JointJS 和 JointJS+ 现在感觉像是一个新库,但这种更改不需要您进行任何学习工作,并且具有非常简单的迁移过程。

关于减小包大小的主题,下面是一个可视化示例,说明了使用 JointJS 构建的简单可视化应用程序的结构。在 4.0 版本之前,应用程序的总大小(包括外部 JointJS 依赖项)为 1.94MB。随着4.0版本的发布,应用程序大小减少至1.1MB,实现了44%的改进。

图表控件

BPMN 导出到 XML 格式/从 XML 格式导入

BPMN 代表业务流程模型和表示法,是一种标准化的建模语言和表示法系统,被企业广泛用来以图形方式描述其业务流程。它使公司能够以全面的方式记录、分析和优化其工作流程。 BPMN 模型可以序列化为 XML 格式,称为 BPMN XML,从而促进跨各种 BPMN 兼容工具(例如 BPMN 编辑器和自动化引擎)轻松交换和存储业务流程图。在 JointJS+ 4.0 中,BPMN 图可以无缝地从 XML 导入或导出到 XML,从而增强整个 BPMN 工具套件之间的协作。

了解导出在BPMN 编辑器中设计的流程并将其导入Camunda以实现端到端流程自动化是多么简单。

图表控件

广泛的重构以提高性能

消除了过时的代码,不仅旨在提高性能,而且还使您与的代码库的交互更加直观。改进的错误消息使调试变得更加容易;默认情况下,所有图表都更快且视觉上更有吸引力。此外,封装的特定部分被分开,进一步减小了封装尺寸。对于仍然可以从的示例中复制并在您的项目中使用但不包含在包中的形状来说,这一点很明显。

此外,在 4.0 版本中,又向成为完全模块化的图表库和构建受益于的核心功能和其他广泛使用的技术的生态系统迈出了重要的一步。结果将是模块形式的大量高级功能,这些功能结合了的核心功能和其他技术(例如D3、Cytoscape或Graphviz )的优势,并且可以选择在您的项目中使用,但不属于 JointJS 和 JointJS+ 的一部分默认为核心。在的积压工作中,在接下来的几周内您可以期待许多有用的功能!

新演示:图像处理器

近发布的演示应用程序“图像处理器”的源代码现在是 JointJS+ 包的一部分,可帮助您复制和粘贴我们的工作并将其作为样板重新用于您自己的项目。图像处理器应用程序使您能够以基于节点的方式使用滤镜和转换工具来处理图像。要访问源代码,

图表控件

其他变化
  • [新功能] 网格现在在纸张内呈现为 SVG 文档(而不是 HTML),并且可以在导出的 SVG、PNG 或打印页面上呈现
  • [新功能] 对纸张转换进行了多项增强,例如触发更高级别的事件、随事件一起传递自定义数据以及简化点方法缩放
  • [新功能]整个框架都支持驼峰式属性
  • [ONBOARDING] 改进了错误消息以方便调试
  • [重构] 已设置合理的默认值,以确保您从一开始就使用高性能的图表
  • [性能] 计算表达式的计算和SVG属性名称设置在核心,可以更有效地更新DOM元素
  • [错误修复] SVG 过滤器现在可以使用链接

http://www.mrgr.cn/p/48762080

相关文章

6. JSP详解

1. 什么是JSP 全称为:Java Server Pages Java服务器端页面,也和Serlvet一样,用于动态Web技术!JSP中的内容就是html,但是能够嵌套java语言 HTML只给用户提供静态数据2. JSP原理服务器内部工作 tomcat中有一个work目录 IDEA中使用Tomcat的会在IDEA的tomcat中生产一个work目录…

【计算机网络】MAC地址简介

MAC(Medium Access Control),即媒介访问控制,是计算机网络通信中的重要概念。每个NIC(Network Interface Card),即网络适配器,都具有独自且不变的MAC地址(烧录的&#xf…

vis.js关系图

代码案例<!DOCTYPE html> <html lang="en"><head><title>Network</title><scripttype="text/javascript"src="https://unpkg.com/vis-network/standalone/umd/vis-network.min.js"></script><styl…

代码随想录算法训练营第四十六天| LeetCode139.单词拆分

一、LeetCode139.单词拆分 题目链接/文章讲解/视频讲解&#xff1a;https://programmercarl.com/0139.%E5%8D%95%E8%AF%8D%E6%8B%86%E5%88%86.html 状态&#xff1a;已解决 1.思路 单词明显就是物品&#xff0c;字符串s明显就是背包&#xff0c;那么问题就变成了物品能不能把背…

梦境绘师:揭秘生成对抗网络(GAN)的魔法

梦境绘师&#xff1a;揭秘生成对抗网络&#xff08;GAN&#xff09;的魔法 1 引言 在今日的深度学习领域&#xff0c;生成对抗网络&#xff08;GAN&#xff09;已成为一项无人能外的技术&#xff0c;以其独特的数据生成能力俘获了无数研究者和工程师的心。这项技术不仅在理论上…

Qt静态编译后使用QtCipherSqlitePlugin静态编译库

Qt静态编译后使用QtCipherSqlitePlugin静态编译库 Qt静态编译后使用QtCipherSqlitePlugin静态编译库语文功底不好,标题起的有点绕口,解释一下:就是我使用的Qt是Qt5.15.2静态编译包(要Qt静态编译文件这里下载:QT5.15.2静态编译包下载 - koomee - 博客园 (cnblogs.com)…

jmeter:测试片段使用的踩坑点

1.坑点:测试片段保存后含有两层【测试片段】,这样引用测试片段是不会成功的,检查方法:打开测试片段看看是否只有一个层级测试片段 2.测试片段的正确使用步骤方法1:选中多个请求或者配置元件>鼠标右键,保存为测试片段(测试实施过程中最常用的方法)方法2:添加测试片…

自学编程两个月,现在我月入 4 万元

这个外国小哥叫 Nico,他一开始是个编程小白,后来把自己关在房间里花了两个月时间学会了编程,如今正在开发一款名为 Talknotes 的应用,可以将语音备忘录转化为结构化的内容,月收入 5000 美元。Nico 从高中毕业就开始创业,大学只上了一个月就退学了,他尝试了很多方向,最终…

echarts折线图使用dataZoom,切换数据时渲染异常,出现竖线bug

今天做项目遇到一个省份过多时,要加滚动条的需求。但是切换数据的时候,出现上图所出现的问题。经查资料,发现可以设置一个属性来解决这个问题。 filterMode: empty dataZoom: {show: this.xiaonengXData.length>12?true:false, // 为true 滚动条出现realtime: this…

ElasticSearch有账号密码时: kibana配置

上一篇文章我们介绍过ElasticSearch关闭账号密码的的方式&#xff1a; config/elasticsearch.yml文件中 xpack.security.enabled: false 当我们关闭 账号密码&#xff0c;kibana是可以直接访问ElasticSearch的。 真实项目中&#xff0c;我们是不允许数据库裸跑的&#xff0c;所…

01 背包的变形

01 背包的变形,退背包的思想消失之物 链接:https://www.luogu.com.cn/problem/P4141 题目描述 ftiasch 有 \(n\) 个物品, 体积分别是 \(w_1,w_2,\dots,w_n\)。由于她的疏忽,第 \(i\) 个物品丢失了。 “要使用剩下的 \(n-1\) 物品装满容积为 \(x\) 的背包,有几种方法呢?”—…

百兆集成网络链接器911105A

百兆集成网络链接器&#xff08;有时也称为百兆网卡&#xff09;是一种硬件设备&#xff0c;主要用于计算机与计算机网络之间的高速数据传输。它的主要功能包括&#xff1a; 1. 高速数据传输&#xff1a;百兆集成网络链接器支持100Mbps的数据传输速率&#xff0c;比之前的以太…

点击事件报错: Cannot set properties of null (setting onclick)

1、正常书写代码如下: 通过外部引用JS文件实现想要的效果时报错,以下是代码的展示。引入css文件 <script type="text/javascript" src="./win.js"></script>HTML代码文件如下:<div class="cl"><div id="mask"…

C++|模板进阶(非类型模板参数+特化)

目录 一、非类型模板参数 二、模板特化 2.1函数模板特化 2.2类模板特化 2.2.1全特化 2.2.2偏特化 三、模板不支持分离编译 四、模板优缺点 一、非类型模板参数 在模板初阶中&#xff0c;所学习的模板的参数是类型形参&#xff0c;但其实还有非类型形参。 类型形参&am…

Win10_x64 21h2调试体系分析

参考 https://www.52pojie.cn/thread-1728894-1-1.html记的笔记,发出来参考下,抛砖引玉,有错误多纠正。还望各位大佬别嘲笑。平台如下:版本 Windows 10 专业版版本号 21H2安装日期 2021-08-23操作系统内部版本 19044.2364体验 Windows Feat…

weditor替代品:uiauto.dev

weditor和uiauto.dev都是出自一个作者,是来自杭州某大厂现在weditor已经不更新了,作者重新写了一个uiauto.dev,界面比weditor更加友好现在还在测试阶段,但基本功能基本具备 demo地址:https://uiauto.devsleep.com/demo/12345 使用方法:https://uiauto.devsleep.com/

IDA技巧——结构体

参考 https://bbs.kanxue.com/thread-266419.htm 本文适用于初次使用IDA的小白(我本身也是小白),大佬请略过。 IDB快照 在我们开始修改结构体之前,首先为最初的IDB做一个快照是良好的习惯,这样可以帮助我们迅速还原某个时间点的IDB状态。比如我们改错了某个数据却没办法撤…

记录一下我hive连不上DataGrip的问题

用户名和密码都没问题&#xff0c;但报如下这个错误&#xff08;确保你的metastore和hiveserver2都是启动的&#xff0c;其次hdfs和yarn也是启动的&#xff09; 原因&#xff1a;是因为我在linux上没启hiveserver2服务 解决&#xff1a; [atguiguhadoop102 hadoop]$ …

PlayerSettings.WebGL.emscriptenArgs设置无效的问题

1)PlayerSettings.WebGL.emscriptenArgs设置无效的问题2)java.lang.NoSuchMethodError的不明崩溃问题3)UE电影摄像机旋转问题4)Android设备游戏切后台后唤起,有概率变卡且黑屏这是第383篇UWA技术知识分享的推送,精选了UWA社区的热门话题,涵盖了UWA问答、社区帖子等技术知…