【曹操】【js-sequence-diagrams】前端js绘制时序图

简介: js-sequence-diagrams画时序图

背景说明:

    因为最近在开发一个新的项目,代号曹操,后续可能会更新许多曹操项目相关的开发技术博文,见证曹操项目的从0到上线到最终的产品,也见证自己从java后台到前端全栈到最后全战的开发dog。。。
曹操项目:
前端:angularjs
后台:java

1、需求描述

最近有个功能需要画出某个组件的服务器与上下游服务器的交互情况,画出交互的时序图,并注明交互信息、时间等内容,类似wireshark的Graph Analysis功能:
wires

2、需求解决

在网上找了很久没有画图的js,百度的echart和蚂蚁的G2都翻遍了,确实功能很强大,但是没有实现时序图的方法,甚至期间还去改了echart的关系图,尝试做个二维的时序图,很可惜,效果很差。。直到遇见了js-sequence-diagrams,这不就是最完美的解决方案吗?我天,天造一双啊!

以下是官方给出的例子:
官网地址:https://bramp.github.io/js-sequence-diagrams/
3

左边为效果图,右边为文本控制。

3、实现方法

3.1、官方文档中给出以下js引用方法:

首先在页面中引用相关js:

<script src="webfont.js"></script>
<script src="snap.svg-min.js"></script>
<script src="underscore-min.js"></script>
<script src="sequence-diagram-min.js"></script>

在html文档中手动添加解析文本:

<div id="diagram"></div>
<script>
  var diagram = Diagram.parse("A->B: Message");
  diagram.drawSVG("diagram", {theme: 'hand'});
</script>

或者使用jQuery引用:

<div class="diagram">A->B: Message</div>
<script>
$(".diagram").sequenceDiagram({theme: 'hand'});
</script>

3.2、结合需求

该需求是从数据库中查出很多交互信息,每画一条线需要一个list数据,后台在查询数据库后会以json格式返回所有数据,该json数据的result为一个大的array,array中又有很多map,其中每个map的key是一样的,value不同,所有的map根据时间排序。

前端拿到数据后,在angular的controller js中按照顺序将每条map数据拼接成js-sequence-diagrams形式的文本画出对应的线条,由此生成一个完整的时序图。具体代码如下:

js引用方法:

sipTraceService.getSipTraceList($scope.sipTrace.connid).then(function(data){
       if( null != data && data != undefined && data.result.length != 0){
           
           var result = data.result;
           var htmlTexts = '';
           //对数据进行迭代
           result.forEach(function(ele,index){
               //格式化时间    
               formatTime = $filter('date')( ele.time,'yyyy-MM-dd HH:mm:ss:sss');
               var htmlText = '';
               var inbound = ele.inbound;
               var ip = ele.ip;
               newIp = ip.split(':')[0];
               //根据inbound的值,判断箭头方向
               if(inbound == 0){
                  htmlText   = newIp+'->'+ele.hostip+':'+'\\n'+'cseq:'+ele.cseq+'\\n'+'Request:'+ele.name+'\\n'+'时间:'+formatTime;
               }else if(inbound == 1){
                   htmlText   = ele.hostip+'->'+newIp+':'+'\\n'+'cseq:'+ele.cseq+'\\n'+'Status:'+ele.name+'\\n'+'时间:'+formatTime;
               }
               htmlTexts+=htmlText+'\n';
           })  
       //画图
           var diagram = Diagram.parse(htmlTexts);    
           diagram.drawSVG("diagram", {theme: 'simple'});
       }else {
           alert('connid不存在!');
       }
    
       });

在html上引用js文件,然后通过在controller里使用js方法处理后台数据,按照js-sequence-diagrams的格式输出文本,最后使用其方法完成画图。

4、效果展示

4

目录
相关文章
|
7天前
|
前端开发 JavaScript 开发者
Express.js与前端框架的集成:React、Vue和Angular的示例与技巧
本文介绍了如何将简洁灵活的Node.js后端框架Express.js与三大流行前端框架——React、Vue及Angular进行集成,以提升开发效率与代码可维护性。文中提供了详细的示例代码和实用技巧,展示了如何利用Express.js处理路由和静态文件服务,同时在React、Vue和Angular中构建用户界面,帮助开发者快速掌握前后端分离的开发方法,实现高效、灵活的Web应用构建。
29 3
|
15天前
|
前端开发 JavaScript
前端ES5 | js —添加元素方法
前端ES5 | js —添加元素方法
|
16天前
|
JavaScript 前端开发
前端JS函数
【9月更文挑战第4天】前端JS函数
21 6
|
20天前
|
开发者 图形学 开发工具
Unity编辑器神级扩展攻略:从批量操作到定制Inspector界面,手把手教你编写高效开发工具,解锁编辑器隐藏潜能
【8月更文挑战第31天】Unity是一款强大的游戏开发引擎,支持多平台发布与高度可定制的编辑器环境。通过自定义编辑器工具,开发者能显著提升工作效率。本文介绍如何使用C#脚本扩展Unity编辑器功能,包括批量调整游戏对象位置、创建自定义Inspector界面及项目统计窗口等实用工具,并提供具体示例代码。理解并应用这些技巧,可大幅优化开发流程,提高生产力。
70 1
|
20天前
|
开发者 图形学 C#
深度解密:Unity游戏开发中的动画艺术——Mecanim状态机如何让游戏角色栩栩如生:从基础设置到高级状态切换的全面指南,助你打造流畅自然的游戏动画体验
【8月更文挑战第31天】Unity动画系统是游戏开发的关键部分,尤其适用于复杂角色动画。本文通过具体案例讲解Mecanim动画状态机的使用方法及原理。我们创建一个游戏角色并设计行走、奔跑和攻击动画,详细介绍动画状态机设置及脚本控制。首先导入动画资源并添加Animator组件,然后创建Animator Controller并设置状态间的转换条件。通过编写C#脚本(如PlayerMovement)控制动画状态切换,实现基于玩家输入的动画过渡。此方法不仅适用于游戏角色,还可用于任何需动态动画响应的对象,增强游戏的真实感与互动性。
45 0
|
20天前
|
Android开发 iOS开发 C#
Xamarin:用C#打造跨平台移动应用的终极利器——从零开始构建你的第一个iOS与Android通用App,体验前所未有的高效与便捷开发之旅
【8月更文挑战第31天】Xamarin 是一个强大的框架,允许开发者使用单一的 C# 代码库构建高性能的原生移动应用,支持 iOS、Android 和 Windows 平台。作为微软的一部分,Xamarin 充分利用了 .NET 框架的强大功能,提供了丰富的 API 和工具集,简化了跨平台移动应用开发。本文通过一个简单的示例应用介绍了如何使用 Xamarin.Forms 快速创建跨平台应用,包括设置开发环境、定义用户界面和实现按钮点击事件处理逻辑。这个示例展示了 Xamarin.Forms 的基本功能,帮助开发者提高开发效率并实现一致的用户体验。
42 0
|
20天前
|
开发者 C# Android开发
明白吗?Xamarin与Native的终极对决:究竟哪种开发方式更适合您的项目需求,让我们一探究竟!
【8月更文挑战第31天】随着移动应用开发的普及,开发者面临多种技术选择。本文对比了跨平台解决方案Xamarin与原生开发方式的优势与劣势。Xamarin使用C#进行跨平台开发,代码复用率高,可大幅降低开发成本;但因基于抽象层,可能影响性能。原生开发则充分利用平台特性,提供最佳用户体验,但需维护多套代码库,增加工作量。开发者应根据项目需求、团队技能和预算综合考量,选择最适合的开发方式。
59 0
|
20天前
|
开发者 Android开发 iOS开发
Xamarin开发者的神器!揭秘你绝不能错过的插件和工具,让你的开发效率飞跃式提升
【8月更文挑战第31天】Xamarin.Forms 是一个强大的框架,让开发者通过单一共享代码库构建跨平台移动应用,支持 iOS、Android 和 Windows。使用 C# 和 XAML,它简化了多平台开发流程,保持一致的用户体验。本指南通过创建一个简单的 “HelloXamarin” 应用介绍 Xamarin.Forms 的基本功能和工作原理。首先配置 Visual Studio 开发环境,然后创建并运行一个包含标题、按钮和消息标签的示例应用,展示如何定义界面布局及处理按钮点击事件。这帮助开发者快速入门 Xamarin.Forms,提高跨平台应用开发效率。
30 0
|
4月前
|
前端开发 JavaScript 网络协议
前端最常见的JS面试题大全
【4月更文挑战第3天】前端最常见的JS面试题大全
86 5
|
4月前
|
JavaScript 前端开发
web前端JS高阶面试题(1),高级开发工程师面试
web前端JS高阶面试题(1),高级开发工程师面试