欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在vue中使用jointjs的方法

 更新時(shí)間:2018年03月24日 10:13:20   作者:溫茶兒  
本篇文章主要介紹了在vue中使用jointjs的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

在vue中引入joint.js的問題,之前在網(wǎng)上搜了很多,都沒有給出一個(gè)確切的答案,搗鼓了兩天終于弄明白了,做個(gè)記錄。
首先,我參考了一篇來自stackoverflow的文章點(diǎn)我點(diǎn)我

看完這篇文章,大家應(yīng)該至少大致怎么做了,下面我們來具體看一下:

首先在vue項(xiàng)目中運(yùn)行npm install jointjs --save

然后在入口文件,我的是main.js,也有可能是app.js中加入下面兩行,把joint.js和jquery作為全局變量

window.$ = require('jquery');
window.joint = require('jointjs');

這里需要注意的是,joint.js依賴backbone、jquery和lodash,在通過script方式引入時(shí),需要一一引入這些文件,但通過vue的npm時(shí)不需要,npm引入的joint.js已經(jīng)默認(rèn)封裝好了這些。

通過這樣引入還不夠,可能會(huì)遇到圖可以正常加載,但無法拖拽的問題,遇到這些問題一般是joint.js和自己vue項(xiàng)目中的環(huán)境沖突了,導(dǎo)致無法讀取或者讀取錯(cuò)誤。

我原來的項(xiàng)目中安裝了element、iview、axios、vuex、jquery,再安裝joint.js后,jointjs無法正常加載,后來重新建了一個(gè)項(xiàng)目,只安裝了element、axios、vuex,為避免jquery和joint.js中的jquery沖突,后來沒有裝jquery。

這樣就行了么?就可以運(yùn)行上文鏈接中的例子了么?像這樣:

<template>
  <div>
    <h1>Home</h1>
    <div id="myholder"></div>
  </div>
</template>

<script>
  export default {
    created() {
      let graph = new joint.dia.Graph;

      let paper = new joint.dia.Paper({
        el: $('#myholder'),
        width: 600,
        height: 200,
        model: graph,
        gridSize: 1
      });

      let rect = new joint.shapes.basic.Rect({
        position: { x: 100, y: 30 },
        size: { width: 100, height: 30 },
        attrs: { rect: { fill: 'blue' }, text: { text: 'my box', fill: 'white' } }
      });

      let rect2 = rect.clone();
      rect2.translate(300);

      let link = new joint.dia.Link({
        source: { id: rect.id },
        target: { id: rect2.id }
      });

      graph.addCells([rect, rect2, link]);
    }
  }
</script>

NoNoNo,注意到這里是把渲染放在了created的生命周期里,根據(jù)vue的生命周期,是無法找到j(luò)oint的掛載div的el: $('#myholder'),也就是說,運(yùn)行會(huì)報(bào)錯(cuò),我的解決方法是把div放了一個(gè)click,把joint的內(nèi)容從created中拿出,放在methods中,需要點(diǎn)擊一下才可顯示哦,還不太完美,以待改進(jìn)(~ ̄▽ ̄)~

也就是說,代碼會(huì)變成這樣:

<template>
  <div>
    <div id="myholder" @click="click_joint"></div>
  </div>
</template>

<script>
  export default {
   methods:{
     click_joint() {
      let graph = new joint.dia.Graph;

      let paper = new joint.dia.Paper({
        el: $('#myholder'),
        width: 600,
        height: 200,
        model: graph,
        gridSize: 1
      });

      let rect = new joint.shapes.basic.Rect({
        position: { x: 100, y: 30 },
        size: { width: 100, height: 30 },
        attrs: { rect: { fill: 'blue' }, text: { text: 'my box', fill: 'white' } }
      });

      let rect2 = rect.clone();
      rect2.translate(300);

      let link = new joint.dia.Link({
        source: { id: rect.id },
        target: { id: rect2.id }
      });

      graph.addCells([rect, rect2, link]);
    }
   }
  }
</script>

點(diǎn)明一下,通過npm引入只要install jointjs就可以,不需要install lodash、backbone、jquery,也不需要在頁面中導(dǎo)入joint.css文件。筆者之前通過script方式引入joint.js,試了很多次,都沒有成功,一直讀取joint.js文件出錯(cuò),如果其他小伙伴嘗試成功,歡迎交流分享。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • VUE子組件的watch不被觸發(fā)問題及解決

    VUE子組件的watch不被觸發(fā)問題及解決

    這篇文章主要介紹了VUE子組件的watch不被觸發(fā)問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue3非遞歸渲染Tree組件的初步實(shí)現(xiàn)代碼

    Vue3非遞歸渲染Tree組件的初步實(shí)現(xiàn)代碼

    這篇文章主要介紹了Vue3非遞歸渲染Tree組件的初步實(shí)現(xiàn),文中通過代碼示例講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定幫助,需要的朋友可以參考下
    2024-05-05
  • 幫助我們高效操作的Virtual?DOM簡單實(shí)現(xiàn)

    幫助我們高效操作的Virtual?DOM簡單實(shí)現(xiàn)

    這篇文章主要為大家介紹了幫助我們高效操作Virtual?DOM簡單實(shí)現(xiàn)及原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • Element 的 el-table 表格實(shí)現(xiàn)單元格合并功能

    Element 的 el-table 表格實(shí)現(xiàn)單元格合并功能

    這篇文章主要介紹了Element 的 el-table 表格實(shí)現(xiàn)單元格合并功能,本文通過示例代碼給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2024-07-07
  • Vue Elenent實(shí)現(xiàn)表格相同數(shù)據(jù)列合并

    Vue Elenent實(shí)現(xiàn)表格相同數(shù)據(jù)列合并

    這篇文章主要為大家詳細(xì)介紹了Vue Elenent實(shí)現(xiàn)表格相同數(shù)據(jù)列合并,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • 使用ElementUI循環(huán)生成的Form表單添加校驗(yàn)

    使用ElementUI循環(huán)生成的Form表單添加校驗(yàn)

    這篇文章主要介紹了使用ElementUI循環(huán)生成的Form表單添加校驗(yàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue3封裝AES(CryptoJS)前端加密解密通信代碼實(shí)現(xiàn)

    vue3封裝AES(CryptoJS)前端加密解密通信代碼實(shí)現(xiàn)

    防止數(shù)據(jù)被爬取,前后端傳參接收參數(shù)需要加密處理,使用AES加密,這篇文章主要給大家介紹了關(guān)于vue3封裝AES(CryptoJS)前端加密解密通信代碼實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • vant組件表單外部的button觸發(fā)form表單的submit事件問題

    vant組件表單外部的button觸發(fā)form表單的submit事件問題

    這篇文章主要介紹了vant組件表單外部的button觸發(fā)form表單的submit事件問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • vue3+elementPlus二次封裝表單的實(shí)現(xiàn)代碼

    vue3+elementPlus二次封裝表單的實(shí)現(xiàn)代碼

    最近使用Vue3+ElementPlus開發(fā)項(xiàng)目,從整體上構(gòu)思組件的封裝。能寫成組件的內(nèi)容都進(jìn)行封裝,方便多個(gè)地方使用,這篇文章給大家介紹了vue3+elementPlus二次封裝表單的實(shí)現(xiàn),并通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • Vue中使用vux的配置詳解

    Vue中使用vux的配置詳解

    這篇文章主要為大家詳細(xì)介紹了Vue中使用vux配置的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05

最新評(píng)論