Comment utiliser Vue pour créer des organigrammes ?
Avec le développement d'Internet, de plus en plus d'applications nécessitent la production d'organigrammes, tels que des organigrammes de flux de travail, des schémas de circuits, etc. En tant que framework frontal très populaire, Vue.js offre une excellente interactivité et maintenabilité, il est donc largement utilisé pour créer des applications d'organigrammes complexes.
Cet article présentera comment utiliser Vue pour implémenter la production d'organigrammes, y compris les étapes suivantes :
- Installer les dépendances nécessaires
- Écrire la structure de base des composants
- Implémenter la fonction glisser-déposer
- Implémenter la ligne de connexion
- implémenter l'édition des nœuds
- Export Flowchart
- Installation des dépendances nécessaires
Tout d'abord, nous devons installer la bibliothèque vue-draggable-resizing, qui est un plug-in Vue très facile à utiliser qui peut réaliser le glisser et fonctions de zoom des éléments. Nous pouvons utiliser l'installation npm :
npm install vue-draggable-resizable --save
- Écrivez la structure de base des composants
Nous devons utiliser les composants Vue pour implémenter l'édition d'organigrammes. Nous devons créer un composant FlowChart qui contient tous les éléments de l'organigramme. Chaque nœud est un composant Node qui représente une étape dans l'organigramme. Les lignes de connexion sont des composants de connexion utilisés pour connecter différents nœuds.
Tout d'abord, nous devons créer un composant FlowChart abstrait dans le fichier FlowChart.vue pour contenir tous les nœuds et lignes de connexion :
<template> <div class="flowchart"> <div class="nodes"> <!-- 组件插槽,用于插入节点 --> <slot name="nodes"></slot> </div> <svg class="connections"> <!-- 组件插槽,用于插入连接线 --> <slot name="connections"></slot> </svg> </div> </template> <script> export default { name: 'FlowChart' } </script>
Nous plaçons les nœuds et les lignes de connexion dans les deux emplacements du composant FlowChart respectivement.
Ensuite, nous devons créer des composants Node et Connection pour représenter les nœuds et les lignes de connexion de l'organigramme :
Node.vue :
<template> <draggable-resizable :w="width" :h="height" :x="x" :y="y"> <div class="node"> <!-- 节点的内容 --> <div class="node-content"> <slot></slot> </div> </div> </draggable-resizable> </template> <script> import VueDraggableResizable from 'vue-draggable-resizable' export default { name: 'Node', components: { VueDraggableResizable }, props: { width: { type: Number, default: 100 }, height: { type: Number, default: 50 }, x: { type: Number, default: 0 }, y: { type: Number, default: 0 } } } </script>
Connection.vue :
<template> <svg class="connection"> <!-- SVG 路径元素,用于绘制连接线 --> <path :d="path"></path> </svg> </template> <script> export default { name: 'Connection', props: { start: Object, end: Object }, computed: { path () { // 计算连接线的路径 const startX = this.start.x + this.start.width / 2 const startY = this.start.y + this.start.height / 2 const endX = this.end.x + this.end.width / 2 const endY = this.end.y + this.end.height / 2 return `M ${startX} ${startY} L ${endX} ${endY}` } } } </script>
Nous utilisons le composant vue-draggable-resizing pour implémenter Pour faire glisser et mettre à l'échelle les nœuds, la largeur, la hauteur, x, y et d'autres attributs du nœud doivent être transmis. La ligne de connexion est tracée à l'aide de l'élément path de SVG et le chemin doit être calculé en fonction de la position et de la taille du nœud.
- Implémenter la fonction glisser-déposer
Afin d'implémenter la fonction glisser-déposer des nœuds, nous devons ajouter des écouteurs d'événement v-on:drag, v-on:dragstop et v-on:resize dans le composant Node . Ils correspondent respectivement au glisser, à la fin du glisser et au redimensionnement du nœud :
<draggable-resizable :w="width" :h="height" :x="x" :y="y" v-on:drag="onDrag" v-on:dragstop="onDragStop" v-on:resize="onResize" > <!-- 节点的内容 --> </draggable-resizable> <script> export default { name: 'Node', methods: { onDrag (pos) { // 拖拽事件处理函数 this.$emit('move', { x: pos.x, y: pos.y }) }, onDragStop (pos) { // 结束拖拽事件处理函数 this.$emit('endMove', { x: pos.x, y: pos.y }) }, onResize (size) { // 调整大小事件处理函数 this.$emit('resize', { width: size.width, height: size.height }) } } } </script>
Nous envoyons des événements au composant parent via la méthode $emit dans ces fonctions de gestion d'événements pour réaliser des mises à jour en temps réel de la position et de la taille du nœud. Dans le composant FlowChart, nous devons écouter ces événements et mettre à jour les informations du nœud :
<template> <div class="flowchart"> <div class="nodes"> <!-- 将节点插入到插槽中 --> <slot name="nodes"></slot> </div> <svg class="connections"> <!-- 将连接线插入到插槽中 --> <slot name="connections"></slot> <!-- 鼠标跟随的连接线 --> <Connection v-if="showConnection" :start="{x: start.x + start.width / 2, y: start.y + start.height / 2, width: start.width, height: start.height}" :end="{x: end.x + end.width / 2, y: end.y + end.height / 2, width: end.width, height: end.height}"/> </svg> </div> </template> <script> import Node from './Node.vue' import Connection from './Connection.vue' export default { name: 'FlowChart', components: { Node, Connection }, data () { return { showConnection: false, start: null, // 起点节点 end: null // 终点节点 } }, methods: { onNodeMove (node, pos) { // 节点拖拽时的事件处理函数 node.x = pos.x node.y = pos.y }, onNodeEndMove (node, pos) { // 节点结束拖拽时的事件处理函数 node.x = pos.x node.y = pos.y this.showConnection = false this.start = null this.end = null }, onNodeResize (node, size) { // 节点调整大小时的事件处理函数 node.width = size.width node.height = size.height }, connectNodes (start, end) { // 连接两个节点 this.showConnection = true this.start = start this.end = end } } } </script>
Nous avons défini trois fonctions de gestion d'événements onNodeMove, onNodeEndMove et onNodeResize pour répondre au glissement, à la fin du glissement et au redimensionnement du nœud. La fonction connectNodes est utilisée pour connecter deux nœuds.
- Implémentation de la ligne de connexion
Dans le composant FlowChart, nous définissons une variable showConnection et deux variables start et end pour enregistrer les informations de la ligne de connexion. Nous devons mettre à jour ces informations via des événements de souris pour tracer la ligne de connexion.
Tout d'abord, nous devons ajouter l'écoute des événements v-on:mousedown et v-on:mouseup dans le composant Node. Ces événements sont utilisés pour détecter si l'utilisateur a sélectionné un nœud :
<draggable-resizable :w="width" :h="height" :x="x" :y="y" v-on:drag="onDrag" v-on:dragstop="onDragStop" v-on:resize="onResize" v-on:mousedown="onMouseDown" v-on:mouseup="onMouseUp" > <!-- 节点的内容 --> </draggable-resizable> <script> export default { name: 'Node', methods: { ... onMouseDown () { // 鼠标按下时选中当前节点 this.$emit('select', this) }, onMouseUp () { // 鼠标松开时取消选中 this.$emit('unselect') } } } </script>
Nous envoyons un événement select au composant parent dans le gestionnaire d'événements onMouseDown pour sélectionner le nœud actuel. Dans le composant FlowChart, nous devons écouter cet événement :
<template> <div class="flowchart"> <div class="nodes"> <!-- 将节点插入到插槽中 --> <slot name="nodes"></slot> </div> <svg class="connections"> <!-- 将连接线插入到插槽中 --> <slot name="connections"></slot> <!-- 鼠标跟随的连接线 --> <Connection v-if="showConnection" :start="{x: start.x + start.width / 2, y: start.y + start.height / 2, width: start.width, height: start.height}" :end="{x: end.x + end.width / 2, y: end.y + end.height / 2, width: end.width, height: end.height}"/> </svg> </div> </template> <script> import Node from './Node.vue' import Connection from './Connection.vue' export default { name: 'FlowChart', components: { Node, Connection }, data () { return { showConnection: false, start: null, // 起点节点 end: null // 终点节点 } }, methods: { ... onSelectNode (node) { // 选中节点时的事件处理函数 if (this.start) { // 已选择起点,连接当前节点 this.end = node this.connectNodes(this.start, this.end) } else { // 选择起点 this.start = node } }, onUnselectNode () { // 取消选中节点时的事件处理函数 this.start = null this.end = null this.showConnection = false } } } </script>
Nous déterminons si le nœud de point de départ est actuellement sélectionné dans la fonction de gestionnaire d'événements onSelectNode, et si c'est le cas, connectons le nœud actuel, sinon, définissons le nœud actuel comme ; point de départ. Dans le gestionnaire d'événements onUnselectNode, désélectionnez le nœud et réinitialisez les informations de la ligne de connexion.
- Réaliser l'édition de nœuds
Afin d'implémenter l'édition de nœuds, nous devons ajouter un bouton d'édition dans Node.vue et écouter son événement de clic :
<template> <draggable-resizable ...> <div class="node"> <div class="node-content" v-on:click="$emit('edit')"> <!-- 节点的内容 --> </div> <button class="edit-button" v-on:click="$emit('edit')"> 编辑 </button> </div> </draggable-resizable> </template> <script> export default { name: 'Node' } </script> <style> .edit-button { position: absolute; bottom: 5px; right: 5px; } </style>
Ensuite, écoutez l'événement d'édition dans FlowChart.vue, et select Afficher une zone de saisie sur le nœud :
<template> <div class="flowchart"> <div class="nodes"> <!-- 将节点插入到插槽中 --> <slot name="nodes"></slot> </div> <svg class="connections"> <!-- 将连接线插入到插槽中 --> <slot name="connections"></slot> <!-- 鼠标跟随的连接线 --> <Connection v-if="showConnection" :start="{x: start.x + start.width / 2, y: start.y + start.height / 2, width: start.width, height: start.height}" :end="{x: end.x + end.width / 2, y: end.y + end.height / 2, width: end.width, height: end.height}"/> </svg> <!-- 编辑区域 --> <div class="edit-panel" v-if="selectedNode"> <h3>编辑节点</h3> <form v-on:submit.prevent="saveNode"> <label for="node-label">节点名称</label> <input id="node-label" type="text" v-model="nodeLabel"> <button type="submit">保存</button> </form> </div> </div> </template> <script> export default { name: 'FlowChart', data () { return { showConnection: false, start: null, // 起点节点 end: null, // 终点节点 selectedNode: null, // 选中的节点 nodeLabel: '' // 当前节点的标签 } }, methods: { ... onSelectNode (node) { // 选中节点时的事件处理函数 if (this.start) { // 已选择起点,连接当前节点 this.end = node this.connectNodes(this.start, this.end) this.selectedNode = null } else { // 选择起点 this.start = node } }, onUnselectNode () { // 取消选中节点时的事件处理函数 this.start = null this.end = null this.showConnection = false this.selectedNode = null }, onEditNode (node) { // 编辑节点时的事件处理函数 this.selectedNode = node this.nodeLabel = node.$slots.default[0].text.trim() }, saveNode () { // 保存节点编辑后的信息 this.selectedNode.$slots.default[0].text = this.nodeLabel this.selectedNode = null } } } </script> <style> .edit-panel { position: absolute; top: 0; right: 0; width: 300px; height: 100%; background: #fff; padding: 20px; box-shadow: -1px 0 10px rgba(0, 0, 0, 0.3); } </style>
Nous avons ajouté this.selectedNode = null dans la fonction de gestionnaire d'événements onSelectNode pour masquer la zone d'édition du nœud. Dans le gestionnaire d'événements onEditNode, nous envoyons un événement d'édition au composant parent pour afficher une zone de saisie permettant de modifier le nœud sélectionné. Nous enregistrons les informations modifiées du nœud dans la fonction de gestionnaire d'événements saveNode.
- Exporter l'organigramme
Enfin, nous pouvons ajouter un bouton d'exportation dans FlowChart.vue pour exporter l'organigramme actuel au format JSON :
<template> <div class="flowchart"> <div class="nodes"> <!-- 将节点插入到插槽中 --> <slot name="nodes"></slot> </div> <svg class="connections"> <!-- 将连接线插入到插槽中 --> <slot name="connections"></slot> <!-- 鼠标跟随的连接线 --> <Connection v-if="showConnection" :start="{x: start.x + start.width / 2, y: start.y + start.height / 2, width: start.width, height: start.height}" :end="{x: end.x + end.width / 2, y: end.y + end.height / 2, width: end.width, height: end.height}"/> </svg> <!-- 编辑区域 --> ... <!-- 导出按钮 --> <button class="export-button" v-on:click="exportFlowchart">导出</button> </div> </template> <script> export default { name: 'FlowChart', methods: { ... exportFlowchart () { // 导出流程图 const nodes = [] const connections = [] this.$slots.nodes.forEach(vnode => { const node = vnode.componentInstance nodes.push({ x: node.x, y: node.y, width: node.width, height: node.height, label: node.$slots.default[0].text.trim() }) })
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Vous pouvez ajouter une fonction au bouton VUE en liant le bouton dans le modèle HTML à une méthode. Définissez la logique de la fonction de méthode et d'écriture dans l'instance Vue.

L'utilisation de bootstrap dans vue.js est divisée en cinq étapes: installer bootstrap. Importer un bootstrap dans main.js. Utilisez le composant bootstrap directement dans le modèle. Facultatif: style personnalisé. Facultatif: utilisez des plug-ins.

Il existe trois façons de se référer aux fichiers JS dans Vue.js: spécifiez directement le chemin à l'aide du & lt; script & gt; étiqueter;; importation dynamique à l'aide du crochet de cycle de vie monté (); et l'importation via la bibliothèque de gestion de l'État Vuex.

L'option Watch dans Vue.js permet aux développeurs d'écouter des modifications de données spécifiques. Lorsque les données changent, regardez déclenche une fonction de rappel pour effectuer des vues de mise à jour ou d'autres tâches. Ses options de configuration incluent immédiatement, qui spécifie s'il faut exécuter un rappel immédiatement, et profond, ce qui spécifie s'il faut écouter récursivement les modifications des objets ou des tableaux.

Vue.js dispose de quatre méthodes pour revenir à la page précédente: $ router.go (-1) $ router.back () utilise & lt; router-link to = & quot; / & quot; Composant Window.History.back (), et la sélection de la méthode dépend de la scène.

Le développement multi-pages VUE est un moyen de créer des applications à l'aide du cadre Vue.js, où l'application est divisée en pages distinctes: Maintenance du code: La division de l'application en plusieurs pages peut rendre le code plus facile à gérer et à maintenir. Modularité: chaque page peut être utilisée comme module séparé pour une réutilisation et un remplacement faciles. Routage simple: la navigation entre les pages peut être gérée par une configuration de routage simple. Optimisation du référencement: chaque page a sa propre URL, ce qui aide le référencement.

Vous pouvez interroger la version Vue en utilisant Vue Devtools pour afficher l'onglet Vue dans la console du navigateur. Utilisez NPM pour exécuter la commande "NPM List -g Vue". Recherchez l'élément VUE dans l'objet "dépendances" du fichier package.json. Pour les projets Vue CLI, exécutez la commande "Vue --version". Vérifiez les informations de la version dans le & lt; script & gt; Tag dans le fichier html qui fait référence au fichier VUE.

L'interception de la fonction dans Vue est une technique utilisée pour limiter le nombre de fois qu'une fonction est appelée dans une période de temps spécifiée et prévenir les problèmes de performance. La méthode d'implémentation est: Importer la bibliothèque Lodash: import {Debounce} de 'Lodash'; Utilisez la fonction Debounce pour créer une fonction d'interception: const debouncedFunction = Debounce (() = & gt; {/ logical /}, 500); Appelez la fonction d'interception et la fonction de contrôle est appelée au plus une fois en 500 millisecondes.
