vue jointjs 拓扑图 自定义shape 按需引入

只展示部分核心代码,完整代码见文章尾部连接

在这里插入图片描述

import 'jointjs/dist/joint.core.css';

// 类库 包含: Paper Graph Cell CellView Element Link 等等
import { dia } from 'jointjs/src/core.mjs';
// 样式库 包含多个分组(basic standard custom ...)
import * as standard from 'jointjs/src/shapes/standard.mjs';
import * as layout from 'jointjs/src/layout/index.mjs';
import * as highlighters from 'jointjs/src/highlighters/index.mjs'
import * as util from 'jointjs/src/util/util.mjs'
import * as linkTools from 'jointjs/src/linkTools/index.mjs'

export default {
	install: function (Vue) {
		let joint = { dia };
		joint.shapes = { standard };
		joint.layout = layout;
		joint.highlighters = highlighters
		joint.util = util
		joint.linkTools = linkTools
		Object.defineProperty(Vue.prototype, '$joint', { value: joint });
	}
};

在这里插入图片描述

mounted() {
    console.log(`[${this.name}] Mounted:`, this.$refs.joint);
    this.init();
    setTimeout(() => {
      // 插入十万条数据
      const total = 6
      // 一次插入 20 条,如果觉得性能不好就减少
      const once = 6
      // 渲染数据总共需要几次
      const loopCount = total / once
      let countOfRender = 0
      let node = []
      let link = []
      function add() {
        // 优化性能,插入不会造成回流
        
        for (let index = 0; index < once; index++) {
          node.push({ id: index+1, label: "node" + (+index+1) })
          link.push({ from: 1, to: index+1 })
        }

        countOfRender += 1
        loop()
      }
      function loop() {
        if (countOfRender < loopCount) {
          window.requestAnimationFrame(add)
        }
      }
      loop()


      this.nodes = node;
      this.links = link;

      // this.nodes = [
      //   { id: 1, label: "node1node1node1" },
      //   { id: 2, label: "node2" },
      //   { id: 3, label: "node3" },
      // ];
      // this.links = [
      //   { from: 1, to: 2 },
      //   { from: 1, to: 3 },
      // ]
    }, 0)
    // this.$emit("init", this.graph);
  },

完整代码看下面的地址

vue-jointjs


在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值