draw.io 网页版二次开发(2):开始修改代码

2024-05-12 18:52

本文主要是介绍draw.io 网页版二次开发(2):开始修改代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一 说明

二 打开开发环境 

1. 代码调整

2. 修改访问链接

 3. 注意

三  部分功能的代码汇总

1.  保存功能

2. 菜单栏折叠按钮功能

3.  顶部菜单栏

4.在顶部菜单栏中的【文件】菜单中新增选项

(1) 方法一:单独增加

(2) 方法二 :使用addMenuItems增加(我这次添加了一个保存到数据库的功能)

5. 底部菜单栏

6. 隐藏底部菜单栏的按钮

7. 左侧节点栏

8. 左侧菜单栏底部的【更多图形】的点击后弹窗

9. 元素右击添加点击事件

10.  查找、替换弹窗

11.  共享按钮隐藏

(1)隐藏页面右上角的共享按钮

(2)隐藏菜单栏【文件】下拉框中的共享按钮

12. 快捷键以及其功能配置

四 最后


一 说明

        应公司项目要求,需要对draw.io进行二次开发,并将html界面通过iframe 嵌入到本公司产品中使用,但是由于功能限制,做到最后还是放弃了使用draw.io。但是之前的研究内容可不能浪费。便准备写个专栏进行记录,希望能够帮到需要将draw.io进行二次开发的朋友,其中有涉及到不正确的地方还请大家多包涵!

二 打开开发环境 

        应该有小伙伴发现,修改代码后,刷新界面,为什么界面没有任何变化。那是因为还需要对某些地方进行调整。具体调整如下:

1. 代码调整

        如下图:在webapp根目录下找到index.html 文件,将黄色方框里面的代码(原始代码)修改为绿色方框的代码(即修改后的代码),这是为了注释掉远程地址 ,否则测试环境下不会请求本地修改后的 js 代码。

2. 修改访问链接

        正常访问是直接访问 http://localhost:3000/,但是开发模式的话,需要在访问url后面加上 ?.dev=1 。即 http://localhost:3000/?dev=1 。 这样,代码中修改的部分就可以看到效果了。

 3. 注意

        文件中有很多后缀为 .min.js 的文件,这个是自动生成的,千万不能改哦。

三  部分功能的代码汇总

1.  保存功能

        代码位置:src/main/webapp/js/diagramly/Dialogs.js        

2. 菜单栏折叠按钮功能

代码位置:src/main/webapp/js/diagramly/App.js

3.  顶部菜单栏

(1) 代码位置:src/main/webapp/js/diagramly/Menus.js

4.在顶部菜单栏中的【文件】菜单中新增选项

        新增选项有两种方式,如下:

        前提,需要添加多语言文件,比如中英对照文件:src/main/webapp/resources/dia_zh.txt

(1) 方法一:单独增加

        文件地址:src/main/webapp/js/diagramly/Menus.js

        ① 添加对应的字段(自己找准添加的位置写代码即可)

        ② 添加对应的点击功能

        ③  刷新界面,运行就可见到新的功能按钮。

(2) 方法二 :使用addMenuItems增加(我这次添加了一个保存到数据库的功能)

        ① 添加菜单按钮,代码位置:src/main/webapp/js/diagramly/Menus.js

        ②  添加点击事件:src/main/webapp/js/grapheditor/Actions.js

        ③  添加快捷键:src/main/webapp/js/grapheditor/EditorUi.js

        ④  保存并刷新界面,运行效果如下:

5. 底部菜单栏

(1) 代码位置:src/main/webapp/js/diagramly/Pages.js

(2) 在菜单栏中添加功能(同样也要先添加多语言对照文件)

(3)保存代码后,刷新界面,点击菜单栏,展示如下效果: 

6. 隐藏底部菜单栏的按钮

代码位置:src/main/webapp/js/diagramly/Pages.js 

7. 左侧节点栏

        

 代码位置:src/main/webapp/js/diagramly/sidebar/Sidebar.js

8. 左侧菜单栏底部的【更多图形】的点击后弹窗

代码位置: src/main/webapp/js/diagramly/Dialogs.js

9. 元素右击添加点击事件

 (1) 添加事件的中英文对应名字:src/main/webapp/resources/dia_zh.txt

(2)  将名字添加到菜单上

        注意:代码中的  -  表示添加一行分割线。

        添加方式有两个(需要看具体放的位置在哪里,看代码具体分析。):

        ① 添加在:src/main/webapp/js/diagramly/EditorUi.js

        ② 添加在:src/main/webapp/js/grapheditor/Menus.js

 (3) 添加点击事件:src/main/webapp/js/grapheditor/Actions.js

        在函数Actions.prototype.init中添加:

(4) 保存后运行效果如下:

10.  查找、替换弹窗

        

 触发事件:src/main/webapp/js/diagramly/Menus.js 中的 init 函数中的 findreplace 事件

弹出的弹窗代码位置: src/main/webapp/js/diagramly/Dialogs.js

11.  共享按钮隐藏

(1)隐藏页面右上角的共享按钮

代码位置: src/main/webapp/js/diagramly/App.js 具体位置如下(注释掉框起来的代码即可)

(2)隐藏菜单栏【文件】下拉框中的共享按钮

代码地址:src/main/webapp/js/diagramly/Menus.js  。具体位置如下(注释掉即可):

12. 快捷键以及其功能配置

代码位置:src/main/webapp/js/grapheditor/EditorUi.js

功能配置: src\main\webapp\js\grapheditor\Actions.js

四 最后

        代码的修改就到这里了。以后要是有其他的记录,我会继续补充。下一章开始写draw.io的打包和部署。

这篇关于draw.io 网页版二次开发(2):开始修改代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/983459

相关文章

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Java实现自定义table宽高的示例代码

《Java实现自定义table宽高的示例代码》在桌面应用、管理系统乃至报表工具中,表格(JTable)作为最常用的数据展示组件,不仅承载对数据的增删改查,还需要配合布局与视觉需求,而JavaSwing... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

Go语言代码格式化的技巧分享

《Go语言代码格式化的技巧分享》在Go语言的开发过程中,代码格式化是一个看似细微却至关重要的环节,良好的代码格式化不仅能提升代码的可读性,还能促进团队协作,减少因代码风格差异引发的问题,Go在代码格式... 目录一、Go 语言代码格式化的重要性二、Go 语言代码格式化工具:gofmt 与 go fmt(一)

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3