首頁 web前端 js教程 在Vue.js中透過遞歸元件如何建構樹狀選單

在Vue.js中透過遞歸元件如何建構樹狀選單

Jun 15, 2018 pm 05:24 PM
vue.js 樹形選單 遞迴組件

這篇文章主要介紹了用Vue.js遞歸元件建立一個可折疊的樹狀選單的教學內容,有興趣的朋友跟著學習下。

在Vue.js中一個遞歸元件呼叫的是其本身,如:

Vue.component('recursive-component', {
 template: `<!--Invoking myself!-->
    <recursive-component></recursive-component>
 });
登入後複製

遞歸元件常用於在blog上顯示註解、巢狀的選單,或基本上是父和子相同的類型,儘管具體內容不同。例如:

現在給您看如何有效地使用遞歸元件,我將透過建立一個可擴展/收縮的樹狀選單的來一步步進行。

資料結構

一個樹狀UI的遞歸元件將會是一些遞歸資料結構的視覺化表達。在本教程中,我們將使用樹狀結構,其中每個節點都是一個物件:

一個 label 屬性。

如果它有子節點,一個 nodes 屬性,則它是一個或多個節點的陣列屬性。

與所有樹狀結構一樣,它必須有一個根節點,但可以無限深。

let tree = {
 label: &#39;root&#39;,
 nodes: [
  {
  label: &#39;item1&#39;,
  nodes: [
   {
   label: &#39;item1.1&#39;
   },
   {
   label: &#39;item1.2&#39;,
   nodes: [
    {
    label: &#39;item1.2.1&#39;
    }
   ]
   }
  ]
  }, 
  {
  label: &#39;item2&#39; 
  }
 ]
 }
登入後複製

遞迴元件

讓我們做一個遞迴元件來顯示我們的稱為 TreeMenu 的資料結構。它只顯示當前節點的標籤,並呼叫自己來顯示任何子節點。檔案名稱:TreeMenu.vue,內容如下:

<template>
 <p class="tree-menu">
  <p>{{ label }}</p>
  <tree-menu 
  v-for="node in nodes" 
  :nodes="node.nodes"
  :label="node.label"
  >
  </tree-menu>
 </p>
 </template>
 <script>
 export default { 
  props: [ &#39;label&#39;, &#39;nodes&#39; ],
  name: &#39;tree-menu&#39;
 }
 </script>
登入後複製

如果你使用一個元件遞歸,必須先給 Vue.component 做一個全域的定義,或者,給它一個 name 屬性。否則,任何子元件將無法進一步呼叫它,你會得到一個不確定的「undefined component error」的錯誤提示。

基本事件

與任何遞歸函數一樣,你需要一個基本事件來結束遞歸,否則渲染將無限期地繼續下去,最終會導致堆疊溢位。

在樹選單中,當我們到達一個沒有子節點的節點的時候,我們希望停止遞歸。你能透過 v-if 做到這項功能,但我們選擇使用 v-for 將隱式地為我們實現它;如果 nodes 數組沒有任何進一步的定義 tree-menu 元件將被呼叫。 template.vue檔案如下:

<template>
 <p class="tree-menu">
  ...
  <!--If `nodes` is undefined this will not render-->
  <tree-menu v-for="node in nodes"></tree-menu>
 </template>
登入後複製

使用用法

我們現在要如何使用這個元件?首先,我們宣告一個Vue實例,具有一個資料結構包括data屬性和定義過的treemenu元件。 app.js檔案如下:

 import TreeMenu from &#39;./TreeMenu.vue&#39;
 let tree = {
 ...
 }
 new Vue({
 el: &#39;#app&#39;,
 data: {
  tree
 },
 components: {
  TreeMenu
 }
 })
登入後複製

請記住,我們的資料結構有一個根節點。我們在主模板開始遞歸呼叫TreeMenu 元件,使用根nodes 屬性來props:

<p id="app">
 <tree-menu :label="tree.label" :nodes="tree.nodes"></tree-menu>
 </p>
登入後複製

下面是它目前的樣子:

## 正確的姿勢

在視覺上辨識子元件的「深度」是很好的,這樣使用者就可以從UI中獲得資料結構的感覺。讓我們縮排每一層的子節點來實現這個目標。

這是透過增加一個depth prop定義,透過 TreeMenu 來實現。我們將使用這個值動態地將內聯樣式與轉換綁定在一起:將使用transform: translate的CSS規則為每個節點的標籤,從而建立縮排。 template.vue修改如下**:**

<template>
 <p class="tree-menu">
  <p :style="indent">{{ label }}</p>
  <tree-menu 
  v-for="node in nodes" 
  :nodes="node.nodes" 
  :label="node.label"
  :depth="depth + 1"
  >
  </tree-menu>
 </p>
 </template>
 <script>
 export default { 
  props: [ &#39;label&#39;, &#39;nodes&#39;, &#39;depth&#39; ],
  name: &#39;tree-menu&#39;,
  computed: {
  indent() {
   return { transform: `translate(${this.depth * 50}px)` }
  }
  }
 }
 </script>
登入後複製

depth 屬性在主模板中從零開始。在上面的元件模板中,你可以看到每次傳遞到任何子節點時這個值都會遞增。

<p id="app">
 <tree-menu 
  :label="tree.label" 
  :nodes="tree.nodes"
  :depth="0"
 ></tree-menu>
 </p>
登入後複製

注意:記得 v-bind depth值以確保它是一個JavaScript數字類型而不是字串。

展開/收起

由於遞歸資料結構可能很大,所以顯示它們的一個很好的UI技巧是隱藏根節點以外的所有節點,以便使用者可以根據需要展開或收起節點。

為此,我們將增加一個局部屬性showChildren 。如果他的值為False,子節點將不會被渲染。此值應透過點擊節點切換,所以我們需要使用一個點擊事件的監聽器方法 toggleChildren 來進行管理。 template.vue檔案修改如下**:**

<template>
 <p class="tree-menu">
  <p :style="indent" @click="toggleChildren">{{ label }}</p>
  <tree-menu 
  v-if="showChildren"
  v-for="node in nodes" 
  :nodes="node.nodes" 
  :label="node.label"
  :depth="depth + 1"
  >
  </tree-menu>
 </p>
 </template>
 <script>
 export default { 
  props: [ &#39;label&#39;, &#39;nodes&#39;, &#39;depth&#39; ],
  data() {
  return { showChildren: false }
  },
  name: &#39;tree-menu&#39;,
  computed: {
  indent() {
   return { transform: `translate(${this.depth * 50}px)` }
  }
  },
  methods: {
  toggleChildren() {
   this.showChildren = !this.showChildren;
  }
  }
 }
 </script>
登入後複製
總結

這樣,我們就有了一個工作樹選單。用來畫龍點睛的一個方法是,你可以添加一個加號/減號圖標,這樣可以讓UI的顯示更加明顯。我還增加了的很好的字體和計算性能在原來 showChildren 的基礎上。

上面是我整理給大家的,希望今後對大家有幫助。

相關文章:

在jQuery如何實作滑鼠響應式淘寶動畫效果

jQuery實作的滑鼠回應緩衝動畫效果

如何實作vue2.0響應式(詳細教學)

#透過JS如何實作文字間歇迴圈捲動效果

詳細講解React中的refs(詳細教學)

#

以上是在Vue.js中透過遞歸元件如何建構樹狀選單的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

深入探討vite是怎麼解析.env檔的 深入探討vite是怎麼解析.env檔的 Jan 24, 2023 am 05:30 AM

使用vue框架開發前端專案時,我們部署的時候都會部署多套環境,往往開發、測試以及線上環境呼叫的介面網域都是不一樣的。如何能做到區分呢?那就是使用環境變數和模式。

圖文詳解如何在Vue專案中整合Ace程式碼編輯器 圖文詳解如何在Vue專案中整合Ace程式碼編輯器 Apr 24, 2023 am 10:52 AM

Ace 是一個用 JavaScript 寫的可嵌入程式碼編輯器。它與 Sublime、Vim 和 TextMate 等原生編輯器的功能和效能相符。它可以很容易地嵌入到任何網頁和 JavaScript 應用程式中。 Ace 被維護為Cloud9 IDE的主要編輯器 ,並且是 Mozilla Skywriter (Bespin) 專案的繼承者。

vue中組件化和模組化有什麼區別 vue中組件化和模組化有什麼區別 Dec 15, 2022 pm 12:54 PM

組件化和模組化的區別:模組化是從程式碼邏輯的角度進行劃分的;方便程式碼分層開發,確保每個每個功能模組的職能一致。元件化是從UI介面的角度進行規劃;前端的元件化,方便UI元件的重複使用。

探討如何在Vue3中撰寫單元測試 探討如何在Vue3中撰寫單元測試 Apr 25, 2023 pm 07:41 PM

在當今前端開發中,Vue.js 已經成為了一個非常流行的框架。隨著 Vue.js 的不斷發展,單元測試變得越來越重要。今天,我們將探討如何在 Vue.js 3 中編寫單元測試,並提供一些最佳實踐和常見的問題及解決方案。

深入聊聊vue3中的reactive() 深入聊聊vue3中的reactive() Jan 06, 2023 pm 09:21 PM

前言:在vue3的開發中,reactive是提供實現響應式資料的方法。日常開發這個是使用頻率很高的api。這篇文章筆者就來探索其內部運作機制。

Vue中JSX語法和模板語法的簡單比較(優劣勢分析) Vue中JSX語法和模板語法的簡單比較(優劣勢分析) Mar 23, 2023 pm 07:53 PM

在Vue.js中,開發人員可以使用兩種不同的語法來建立使用者介面:JSX語法和範本語法。這兩種文法各有優劣,以下就來探討它們的差異和優劣勢。

怎麼查詢目前vue的版本 怎麼查詢目前vue的版本 Dec 19, 2022 pm 04:55 PM

查詢目前vue版本的兩種方法:1、在cmd控制台內,執行「npm list vue」指令查詢版本,輸出結果就是vue的版本號資訊;2、在專案中找到並開啟package.json文件,查找「dependencies」項目即可看到vue的版本資訊。

淺析Vue3動態組件怎麼進行異常處理 淺析Vue3動態組件怎麼進行異常處理 Dec 02, 2022 pm 09:11 PM

Vue3動態元件怎麼進行異常處理?以下這篇文章帶大家聊聊Vue3 動態元件異常處理的方法,希望對大家有幫助!

See all articles