從零開始打造流程圖、拓撲圖專案【Nuxt.js + Element + Vuex】
一 、通過雲開發平臺快速建立初始化應用
1.建立相關應用模版請參考連結: 基於 vue.js 的 SSR 技術—Nuxt.js
// 注意在後面提示中,上移下移,按空格選中 Element
2.完成建立後就可以在github中檢視到新增的Nuxt倉庫
二 、 本地編寫 流程圖、拓撲圖專案
1.將應用模版克隆到本地
git clone + 專案地址
cd nuxtJs
git checkout feature/1.0.0
npm install
npm run dev
2.專案框架
head: { title: '樂吾樂 Topology - 開源免費繪圖工具', meta: [ { charset: 'utf-8' }, { name: 'viewport', content: 'width=device-width, initial-scale=1' }, { hid: 'description', name: 'description', content: '一個基於typescript + canvas的好用開源繪圖工具和繪圖引擎。易整合到自己的前端專案、還可以方便自定義圖形庫,支援微服務架構圖、流程圖、時序圖、活動圖、類圖等' } ], link: [ { rel: 'icon', type: 'image/x-icon', href: '/favicon.ico' }, { rel: 'stylesheet', href: '//at.alicdn.com/t/font_1113798_0532l8oa6jqp.css' }, { rel: 'stylesheet', href: '//at.alicdn.com/t/font_1331132_5lvbai88wkb.css' } ] },
3.新增SCSS支援
yarn add node-sass sass-loader -D
<style> .page { width: 100%; height: 100%; } </style>
4.新增一個全域性公用css
import '~/assets/css/base.scss'
5.網頁佈局
6.建立畫布
// 先匯入庫 import { Topology, Options, registerNode } from '@topology/core'; import { register as registerFlow } from '@topology/flow-diagram'; import { register as registerActivity } from '@topology/activity-diagram'; import { register as registerClass } from '@topology/class-diagram'; import { register as registerSequence } from '@topology/sequence-diagram'; import { register as registerChart } from '@topology/chart-diagram'; // 註冊圖形庫 canvasRegister() { registerFlow(); registerActivity(); registerClass(); registerSequence(); registerChart(); // ... }
7.載入圖形庫
data() { return { // 左側工具欄 tools: Tools, // 圖形庫 canvas: {}, // 圖形庫選項:{ rotateCursor: '/img/rotate.cur' }, // 右側屬性欄資料 props: { node: null, line: null, multi: false } } }
created() { canvasRegister() }
mounted() { this.canvasOptions.on = this.onMessage this.canvas = new Topology('topology-canvas', this.canvasOptions) }
<a v-for="(btn, i) in item.children" :key="i" :title="btn.name" :draggable="btn.data" @dragstart="onDrag($event, btn)" > <i :class="`iconfont ${btn.icon}`"></i> </a>
methods: { onDrag(event, node) { event.dataTransfer.setData('Text', JSON.stringify(node.data)) } }
8.右側屬性欄
<template> <div> <!-- 選中為空 --> <div v-if="!props.node && !props.line && !props.multi"> <div>歡迎使用le5le-topology!</div> <div> <a href="喜歡,點選這裡打個star吧</a> <a href="https://ology" target="_blank">使用教程</a> <br /> <a href="微信交流群(大群)</a> <br /> <a href="微信交流群2</a> <br /> <a href="https://ology/faq#EVbCgt" target="_blank">聯絡我們</a> </div> <div>[Todo] 未來規劃</div> <ul> <li>Github issues</li> <li>React demo</li> <li>Vue3 demo</li> <li>系列教程</li> </ul> <div> <div>小提示</div> <ul> <li>方向鍵:控制節點移動5個畫素</li> <li>Ctrl + 方向鍵:控制節點移動1個畫素</li> <li>Ctrl + 滑鼠移動:移動整個畫布</li> <li>Ctrl + 滑鼠滾輪:縮放</li> <li>新增或選中節點,右側屬性支援上傳各種圖片哦</li> </ul> </div> </div> <!-- 選中節點 --> <div v-if="props.node"> <div>位置和大小</div> <div> <div class="flex grid"> <div>X(px)</div> <div>Y(px)</div> </div> <div class="flex grid"> <div> <el-input-number v-model="props.node.rect.x" controls-position="right" @change="onChange" ></el-input-number> </div> <div> <el-input-number v-model="props.node.rect.y" controls-position="right" @change="onChange" ></el-input-number> </div> </div> </div> <div> <div class="flex grid"> <div>寬(px)</div> <div>高(px)</div> </div> <div class="flex grid"> <div> <el-input-number v-model="props.node.rect.width" controls-position="right" @change="onChange" ></el-input-number> </div> <div> <el-input-number v-model="props.node.rect.height" controls-position="right" @change="onChange" ></el-input-number> </div> </div> </div> </div> </div> </template> <script > export default { data() { return {} }, props: { props: { type: Object, require: true } }, methods: { onChange(value) { this.$emit('change', this.props.node) } } } </script>
<div> <CanvasProps :props.sync="props" @change="onUpdateProps"></CanvasProps> </div>
onUpdateProps(node) { // 如果是畫布已選中的節點,無需傳引數 this.canvas.updateProps() // 如果畫布沒有選中節點,需要傳相關引數,參考:https://ology/canvas#v4OFi this.canvas.updateProps(true, [node]) }
三 、 雲端一鍵部署上線應用
1.上傳程式碼
git add . git commit -m '新增你的註釋' git push
2.在日常環境部署
3.配置自定義域名線上上環境上線
4.專案預覽效果
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70003733/viewspace-2896946/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 優思學院:如何同時高效地管理多個專案?
- 造個海洋球池來學習物理引擎【Three.js系列】
- 直觀易用!推薦兩款JSON視覺化工具,配合Swagger使用真香!
- 新藥研發專案管理方案:PM專案提供製藥行業四大功能
- 高效的工程專案管理軟體應具備什麼?
- 基於.NetCore開發部落格專案 StarBlog - (8) 分類層級結構展示
- 製造業SRM管理系統:供應商全方位閉環管理,實現採購尋源與流程高效協同
- Three.js系列: 造個海洋球池來學習物理引擎
- Python常用標準庫(pickle序列化和JSON序列化)
- 發現一個開源專案優化點,點進來就是你的了
- 璞華易投:股權投資募、投、管、退全流程管理平臺
- 基於 vue.js 的 SSR 技術 — Nuxt.js
- 將Abp移植進.NET MAUI專案(一):搭建專案
- 一文學會Java的互動式程式設計環境jshell
- 全網最硬核的Element-UI從Vue-cli遷移至Vite(二)