Vue使用jsmind實現(xiàn)生成腦圖的示例代碼
項目部分參數(shù):
vue:2.6.10
node:16.20.0
1、使用命令行安裝jsmind
npm i jsmind -S
2、在文件中引入jsmind,并編寫渲染jsmind的代碼
<template>
<!-- jsmind容器 -->
<div
id="jsmindContainer"
ref="jsmindContainer"
></div>
</template>
<script>
// 引入jsmind方法和樣式
import "jsmind/style/jsmind.css";
import jsMind from "jsmind";
// 引入獲取數(shù)據(jù)的接口
import { getProjectMind } from "@/api/projectManagement";
export default {
data() {
return {
treeData: {},
jsmind: ""
};
},
created() {
this.initData();
},
beforeDestroy() {
if (this.jsmind) {
this.jsmind.destroy();
}
},
methods: {
initData() {
let projectId = this.$route.query.projectId;
getProjectMind(projectId)
.then(res => {
if (res.code === 200) {
this.treeData = res.data;
const options = {
container: "jsmindContainer", // 必選,容器ID
editable: false, // 可選,是否啟用編輯
theme: "asphalt", // 可選,主題
shortcut: {
enable: true // 禁用快捷鍵
},
layout: {
hspace: 50, // 節(jié)點之間的水平間距
vspace: 20, // 節(jié)點之間的垂直間距
pspace: 13 // 節(jié)點與連接線之間的水平間距(用于容納節(jié)點收縮/展開控制器)
},
mode: "full" // 顯示模式,子節(jié)點只分布在根節(jié)點右側(cè)
};
// 初始化jsMind對象
this.jsmind = new jsMind(options);
// 讓jsmind對象顯示具體的腦圖數(shù)據(jù)
this.jsmind.show({
meta: {
name: "jsMind",
author: "",
version: "0.1"
},
format: "node_tree",// 數(shù)據(jù)格式官方文檔有介紹
data: this.treeData
});
}
})
.catch(err => {});
}
}
};
</script>
重啟項目,報錯unexpected token...,我還以為是引入jsmind的方法不對,后來我直接引入jsmind/es6/jsmind文件還是不行,也沒有搜索到任何解決辦法,我就嘗試安裝低版本的jsmind,安裝了0.5.0版本的jsmind,重啟項目OK了。
3、點擊腦圖部分節(jié)點,展示詳情彈窗
在準備腦圖數(shù)據(jù)的時候,我們將部分節(jié)點數(shù)據(jù)設(shè)計成了這樣:

topic里面是a標簽,當點擊a標簽的時候,會觸發(fā)showTask事件,展示詳情彈窗。
但是在腦圖渲染出來之后,才發(fā)現(xiàn)在method里面注冊的showTask事件,是觸發(fā)不了的。后面嘗試著將topic數(shù)據(jù)里面的onclick換為@click,看vue能否正常將其渲染為a標簽的點擊事件,結(jié)果還是不行,估計是因為jsmind使用了canvas,vue沒有將canvas里面的元素變?yōu)槟0鍢撕灐?/p>
怎么解決呢?我使用了window來幫忙注冊事件,這樣全局就有了showTask事件,點擊a標簽?zāi)軌蛘S|發(fā)了。
// 因為window里面的this不是指向當前組件,所以需要提前注冊使用
window.$$this = this;
window.showTask = function(id) {
// 展示詳情彈窗
window.$$this.detailShow = true;
// 詳情彈窗獲取數(shù)據(jù)
window.$$this.$nextTick(() => {
window.$$this.$refs.TaskDetail.init(id);
});
};
最后要注意在組件的beforeDestroy生命周期中,清除數(shù)據(jù):
beforeDestroy() {
if (this.jsmind) {
this.jsmind.destroy();
window.showTask = undefined;
window.$$this = undefined;
}
}
到此這篇關(guān)于Vue使用jsmind實現(xiàn)生成腦圖的示例代碼的文章就介紹到這了,更多相關(guān)Vue jsmind生成腦圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue3與webpack5安裝element-plus樣式webpack編譯報錯問題解決
這篇文章主要介紹了vue3與webpack5安裝element-plus樣式webpack編譯報錯,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04
Vue3?使用Element?Plus表格單選帶checkbox功能
這篇文章主要介紹了Vue3?使用Element?Plus表格單選帶checkbox,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-11-11
vue+watermark-dom實現(xiàn)頁面水印效果(示例代碼)
watermark.js 是基于 DOM 對象實現(xiàn)的 BS 系統(tǒng)的水印,確保系統(tǒng)保密性,安全性,降低數(shù)據(jù)泄密風(fēng)險,簡單輕量,支持多屬性配置,本文將通過 vue 結(jié)合 watermark-dom 庫,教大家實現(xiàn)簡單而有效的頁面水印效果,感興趣的朋友跟隨小編一起看看吧2024-07-07
vue 實現(xiàn)在函數(shù)中觸發(fā)路由跳轉(zhuǎn)的示例
今天小編就為大家分享一篇vue 實現(xiàn)在函數(shù)中觸發(fā)路由跳轉(zhuǎn)的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09
vue實現(xiàn)錄音并轉(zhuǎn)文字功能包括PC端web手機端web(實現(xiàn)過程)
vue實現(xiàn)錄音并轉(zhuǎn)文字功能,包括PC端,手機端和企業(yè)微信自建應(yīng)用端,本文通過實例代碼介紹vue實現(xiàn)錄音并轉(zhuǎn)文字功能包括PC端web手機端web,感興趣的朋友跟隨小編一起看看吧2024-08-08
Vue內(nèi)聯(lián)處理器中訪問方法和訪問事件參數(shù)詳解
在 Vue 3 中,使用組合式 API 時,可以通過內(nèi)聯(lián)事件處理器來直接在模板中編寫事件處理邏輯,內(nèi)聯(lián)事件處理器不僅可以直接執(zhí)行簡單的操作,還可以調(diào)用組件中的方法,并訪問事件參數(shù),下面將詳細講解如何在內(nèi)聯(lián)事件處理器中調(diào)用方法以及訪問事件參數(shù),需要的朋友可以參考下2024-12-12

