vue 动态生成拓扑图的示例


Posted in Vue.js onJanuary 03, 2021

横向拓扑

在 index.html 文件中引入文件。

<link href="https://magicbox.bk.tencent.com/static_api/v3/assets/bootstrap-3.3.4/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet">
 <link href="https://magicbox.bk.tencent.com/static_api/v3/assets/bkTopology-1.1/css/bkTopology.css" rel="external nofollow" rel="stylesheet">
 <script src="https://magicbox.bk.tencent.com/static_api/v3/assets/js/jquery-1.10.2.min.js"></script>
 <script src="https://magicbox.bk.tencent.com/static_api/v3/assets/bootstrap-3.3.4/js/bootstrap.min.js"></script>
 <script src="https://magicbox.bk.tencent.com/static_api/v3/assets/bkTopology-1.2/js/bkTopology.js"></script>

在需要绘制拓扑图的组件进行编程。

<template>
 <div>
  <span>S型拓扑图</span>
  <div class="bktopo-container">
   <div class="bktopo_demo" id="bktopo_demo2">
    <div class="none node" id="node-templates" data-container="body" data-placement="top" data-html="true"
     data-trigger="hover">
     <div class="node-container"><span class="node-text"></span></div>
    </div>
    <div class="bktopo_box" style="height:350px;"></div>
   </div>
  </div>
 </div>
</template>
<script>
 export default {
  data() {
   return {
    data: {
     "nodes": [
      { "id": "root", "x": 10, "y": 152, "height": 50, "width": 120, "text": "卡机健康度", "className": "info" },
      { "id": "child1", "x": 200, "y": 30, "height": 50, "width": 120, "text": "进程CPU监控", "className": "info" },
      { "id": "child2", "x": 200, "y": 90, "height": 50, "width": 120, "text": "网管网络故障监控", "className": "info" },
      { "id": "child3", "x": 200, "y": 150, "height": 50, "width": 120, "text": "进程内在泄露监控", "className": "info" },
      { "id": "child4", "x": 200, "y": 210, "height": 50, "width": 120, "text": "进程存活监控", "className": "info" },
      { "id": "child5", "x": 200, "y": 270, "height": 50, "width": 120, "text": "用户内在使用监控", "className": "info" },
      { "id": "child1_1", "x": 380, "y": 30, "height": 50, "width": 120, "text": "监控正常无触发自愈", "className": "success" },
      { "id": "child2_1", "x": 380, "y": 90, "height": 50, "width": 120, "text": "监控正常无触发自愈", "className": "success" },
      { "id": "child3_1", "x": 380, "y": 150, "height": 50, "width": 120, "text": "发现异常触发自愈", "className": "danger" },
      { "id": "child3_2", "x": 560, "y": 150, "height": 50, "width": 120, "text": "重启进程正常", "className": "success" },
      { "id": "child4_1", "x": 380, "y": 210, "height": 50, "width": 120, "text": "发现异常触发自愈", "className": "danger" },
      { "id": "child4_2", "x": 560, "y": 210, "height": 50, "width": 120, "text": "重启进程正常", "className": "success" },
      { "id": "child5_1", "x": 380, "y": 270, "height": 50, "width": 120, "text": "发现异常触发自愈", "className": "success" },
     ],
     "edges": [
      { "source": "root", "sDirection": 'right', "target": "child1", "tDirection": 'left', "edgesType": "info" },
      { "source": "root", "sDirection": 'right', "target": "child2", "tDirection": 'left', "edgesType": "info" },
      { "source": "root", "sDirection": 'right', "target": "child3", "tDirection": 'left', "edgesType": "info" },
      { "source": "root", "sDirection": 'right', "target": "child4", "tDirection": 'left', "edgesType": "info" },
      { "source": "root", "sDirection": 'right', "target": "child5", "tDirection": 'left', "edgesType": "info" },
      { "source": "child1", "sDirection": 'right', "target": "child1_1", "tDirection": 'left', "edgesType": "success" },
      { "source": "child2", "sDirection": 'right', "target": "child2_1", "tDirection": 'left', "edgesType": "success" },
      { "source": "child3", "sDirection": 'right', "target": "child3_1", "tDirection": 'left', "edgesType": "danger" },
      { "source": "child3_1", "sDirection": 'right', "target": "child3_2", "tDirection": 'left', "edgesType": "success" },
      { "source": "child4", "sDirection": 'right', "target": "child4_1", "tDirection": 'left', "edgesType": "danger" },
      { "source": "child4_1", "sDirection": 'right', "target": "child4_2", "tDirection": 'left', "edgesType": "success" },
      { "source": "child5", "sDirection": 'right', "target": "child5_1", "tDirection": 'left', "edgesType": "success" }
     ]
    }
   }
  },
  mounted() {
   this.init()
  },
  methods: {
   init() {
    $('#bktopo_demo2 .bktopo_box').bkTopology({
     data: this.data, //配置数据源
     lineType: [ //配置线条的类型
      { type: 'success', lineColor: '#46C37B' },
      { type: 'info', lineColor: '#4A9BFF' },
      { type: 'warning', lineColor: '#f0a63a' },
      { type: 'danger', lineColor: '#c94d3c' },
      { type: 'default', lineColor: '#aaa' }
     ]
    });
   }
  },
 }
</script>
<style scoped>

</style>

S型拓扑

和上面横向一样,需要在 index.html 文件中引用 js 文件。

<template>
 <div>
  <span>横向拓扑图</span>
  <div class="bktopo-container">
   <div class="bktopo_demo" id="bktopo_demo2">
    <div class="none node" id="node-templates" data-container="body" data-placement="top" data-html="true"
     data-trigger="hover">
     <div class="node-container"><span class="node-text"></span></div>
    </div>
    <div class="bktopo_box" style="height:350px;"></div>
   </div>
  </div>
 </div>
</template>
<script>
 export default {
  data() {
   return {
    data: {
     "nodes": [
      {
       "id": "demo3_node1", "x": 100, "y": 50, "height": 50,
       "width": 100, "text": "发起", "className": "node success"
      },
      {
       "id": "demo3_node2", "x": 250, "y": 50, "height": 50,
       "width": 100, "text": "过程1", "className": "node success"
      },
      {
       "id": "demo3_node3", "x": 400, "y": 50, "height": 50,
       "width": 100, "text": "过程2", "className": "node danger"
      },
      {
       "id": "demo3_node4", "x": 550, "y": 50, "height": 50,
       "width": 100, "text": "过程3", "className": "node success"
      },
      {
       "id": "demo3_node5", "x": 550, "y": 150, "height": 50,
       "width": 100, "text": "过程4", "className": "node success"
      },
      {
       "id": "demo3_node6", "x": 400, "y": 150, "height": 50,
       "width": 100, "text": "过程5", "className": "node warning"
      },
      {
       "id": "demo3_node7", "x": 250, "y": 150, "height": 50,
       "width": 100, "text": "过程6", "className": "node success"
      },
      {
       "id": "demo3_node8", "x": 100, "y": 150, "height": 50,
       "width": 100, "text": "过程7", "className": "node success"
      },
     ],
     "edges": [
      {
       "source": "demo3_node1", "sDirection": 'right',
       "target": "demo3_node2", "tDirection": 'left', "edgesType": "success"
      },
      {
       "source": "demo3_node2", "sDirection": 'right',
       "target": "demo3_node3", "tDirection": 'left', "edgesType": "danger"
      },
      {
       "source": "demo3_node3", "sDirection": 'right',
       "target": "demo3_node4", "tDirection": 'left', "edgesType": "success"
      },
      {
       "source": "demo3_node4", "sDirection": 'right',
       "target": "demo3_node5", "tDirection": 'right', "edgesType": "success"
      },
      {
       "source": "demo3_node5", "sDirection": 'right',
       "target": "demo3_node6", "tDirection": 'right', "edgesType": "warning"
      },
      {
       "source": "demo3_node6", "sDirection": 'right',
       "target": "demo3_node7", "tDirection": 'right', "edgesType": "success"
      },
      {
       "source": "demo3_node7", "sDirection": 'right',
       "target": "demo3_node8", "tDirection": 'right', "edgesType": "success"
      },
     ]
    }
   }
  },
  mounted() {
   this.init()
  },
  methods: {
   init() {
    $('#bktopo_demo2 .bktopo_box').bkTopology({
     data: this.data, //配置数据源
     lineType: [ //配置线条的类型
      { type: 'success', lineColor: '#46C37B' },
      { type: 'info', lineColor: '#4A9BFF' },
      { type: 'warning', lineColor: '#f0a63a' },
      { type: 'danger', lineColor: '#c94d3c' },
      { type: 'default', lineColor: '#aaa' }
     ]
    });
   }
  },
 }
</script>
<style scoped>

</style>

纵向拓扑

和上面横向一样,需要在 index.html 文件中引用 js 文件。

<template>
 <div>
  <span>纵向拓扑图</span>
  <div class="bktopo-container">
   <div class="bktopo_demo" id="bktopo_demo2">
    <div class="none node" id="node-templates" data-container="body" data-placement="top" data-html="true"
     data-trigger="hover">
     <div class="node-container"><span class="node-text"></span></div>
    </div>
    <div class="bktopo_box" style="height:350px;"></div>
   </div>
  </div>
 </div>
</template>
<script>
 export default {
  data() {
   return {
    data: {
     "nodes": [
      {
       "id": "node1", "x": 361, "y": 20, "height": 50, "width": 180,
       "text": "浏览器发起'www.qq.com'请求", "className": "node success"
      },
      {
       "id": "node2",
       "x": 391, "y": 100, "height": 50, "width": 120, "text": "本地hosts文件解析",
       "className": "node success"
      },
      {
       "id": "node3", "x": 301, "y": 200, "height": 50, "width": 100, "text": "客户接入联通网", "className": "node"
      },
      {
       "id": "node4", "x": 400, "y": 200, "height": 50, "width": 100, "text": "客户接入移动网", "className": "node"
      },
      {
       "id": "node5", "x": 499, "y": 200, "height": 50, "width": 100, "text": "客户接入电信网",
       "className": "node success", "title": "如果hosts匹配成功则不经过DNS服务器解析。直接使用IP访问"
      },
      {
       "id": "node6", "x": 233, "y": 300, "height": 50, "width": 140, "text": "联通DNS服务器", "className": "node"
      },
      {
       "id": "node7", "x": 372, "y": 300, "height": 50, "width": 140, "text": "移动DNS服务器", "className": "node"
      },
      {
       "id": "node8", "x": 511, "y": 300, "height": 50, "width": 140, "text": "电信DNS服务器",
       "className": "node success"
      },
      {
       "id": "node9", "x": 233, "y": 400, "height": 50, "width": 370,
       "text": "核心骨干交换网集群", "className": "node success"
      },
      {
       "id": "node19", "x": 343, "y": 500, "height": 50, "width": 150,
       "text": "WEb服务器", "className": "node success"
      },
     ],
     "edges": [
      { "source": "node1", "sDirection": 'bottom', "target": "node2", "tDirection": 'top', "edgesType": "success" },
      { "source": "node2", "sDirection": 'bottom', "target": "node5", "tDirection": 'top', "edgesType": "success" },
      { "source": "node3", "sDirection": 'bottom', "target": "node6", "tDirection": 'top', "edgesType": "danger" },
      { "source": "node6", "sDirection": 'bottom', "target": "node9", "tDirection": 'left', "edgesType": "danger" },
      { "source": "node4", "sDirection": 'bottom', "target": "node7", "tDirection": 'top', "edgesType": "danger" },
      { "source": "node5", "sDirection": 'bottom', "target": "node8", "tDirection": 'top', "edgesType": "success" },
      { "source": "node7", "sDirection": 'bottom', "target": "node9", "tDirection": 'top', "edgesType": "danger" },
      { "source": "node8", "sDirection": 'bottom', "target": "node9", "tDirection": 'right', "edgesType": "danger" },
      { "source": "node9", "sDirection": 'bottom', "target": "node19", "tDirection": 'top', "edgesType": "success" }
     ]
    }
   }
  },
  mounted() {
   this.init()
  },
  methods: {
   init() {
    $('#bktopo_demo2 .bktopo_box').bkTopology({
     data: this.data, //配置数据源
     lineType: [ //配置线条的类型
      { type: 'success', lineColor: '#46C37B' },
      { type: 'info', lineColor: '#4A9BFF' },
      { type: 'warning', lineColor: '#f0a63a' },
      { type: 'danger', lineColor: '#c94d3c' },
      { type: 'default', lineColor: '#aaa' }
     ]
    });
   }
  },
 }
</script>
<style scoped>

</style>

vue 动态生成拓扑图的示例

以上就是vue 动态生成拓扑图的示例的详细内容,更多关于vue 生成拓扑图的资料请关注三水点靠木其它相关文章!

Vue.js 相关文章推荐
Vue如何循环提取对象数组中的值
Nov 18 Vue.js
在Vue中使用CSS3实现内容无缝滚动的示例代码
Nov 27 Vue.js
vue 在服务器端直接修改请求的接口地址
Dec 19 Vue.js
vue-quill-editor插入图片路径太长问题解决方法
Jan 08 Vue.js
vscode自定义vue模板的实现
Jan 27 Vue.js
vue项目实现分页效果
Mar 24 Vue.js
浅谈vue2的$refs在vue3组合式API中的替代方法
Apr 18 Vue.js
Vue CLI中模式与环境变量的深入详解
May 30 Vue.js
vue项目多环境配置(.env)的实现
Jul 21 Vue.js
vue自定义右键菜单之全局实现
Apr 09 Vue.js
解决vue-router的beforeRouteUpdate不能触发
Apr 14 Vue.js
Vue中强制组件重新渲染的正确方法
Jan 03 #Vue.js
vue中activated的用法
Jan 03 #Vue.js
vue实现登录功能
Dec 31 #Vue.js
vue 实现图片懒加载功能
Dec 31 #Vue.js
vue 动态创建组件的两种方法
Dec 31 #Vue.js
Vue 修改网站图标的方法
Dec 31 #Vue.js
Vue中inheritAttrs的使用实例详解
Dec 31 #Vue.js
You might like
PHP的FTP学习(四)
2006/10/09 PHP
php网站地图生成类示例
2014/01/13 PHP
PHP过滤★等特殊符号的正则
2014/01/27 PHP
简单解析PHP程序的运行流程
2016/06/23 PHP
ThinkPHP5.1框架数据库链接和增删改查操作示例
2019/08/03 PHP
指定位置如果有图片显示图片,无图片显示广告的JS
2010/06/05 Javascript
jquery.validate使用攻略 第三部
2010/07/01 Javascript
javascript 实现字符串反转的三种方法
2013/11/23 Javascript
jQuery简单实现banner图片切换
2014/01/02 Javascript
Jquery操作radio的简单实例
2014/01/06 Javascript
jQuery控制div实现随滚动条滚动效果
2016/06/07 Javascript
Canvas 绘制粒子动画背景
2017/02/15 Javascript
vue实现仿淘宝结账页面实例代码
2017/11/08 Javascript
nodejs async异步常用函数总结(推荐)
2017/11/17 NodeJs
vue.js动画中的js钩子函数的实现
2018/07/06 Javascript
angularJs提交文本框数据到后台的方法
2018/10/08 Javascript
微信小程序下拉菜单效果的实例代码
2019/05/14 Javascript
pycharm 使用心得(三)Hello world!
2014/06/05 Python
利用Python中unittest实现简单的单元测试实例详解
2017/01/09 Python
Python常见内置高效率函数用法示例
2018/07/31 Python
Python中GIL的使用详解
2018/10/03 Python
python实现自动化上线脚本的示例
2019/07/01 Python
Python 3 判断2个字典相同
2019/08/06 Python
python实现超市管理系统(后台管理)
2019/10/25 Python
详解pandas绘制矩阵散点图(scatter_matrix)的方法
2020/04/23 Python
jupyter notebook的安装与使用详解
2020/05/18 Python
html5 Web SQL Database 之事务处理函数transaction与executeSQL解析
2013/11/07 HTML / CSS
100%植物性、有机、即食餐:Sakara Life
2018/10/25 全球购物
L’urv官网:精品女性运动服品牌
2019/07/07 全球购物
意大利顶级奢侈品电商:LUISAVIAROMA(支持中文)
2020/05/26 全球购物
教师求职信范文
2014/05/24 职场文书
2014年小学语文工作总结
2014/12/20 职场文书
浅谈sql_@SelectProvider及使用注意说明
2021/08/04 Java/Android
Java面试题冲刺第十九天--数据库(4)
2021/08/07 Java/Android
Go语言 详解net的tcp服务
2022/04/14 Golang
python单向链表实例详解
2022/05/25 Python