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

Vue2遞歸組件實(shí)現(xiàn)樹(shù)形菜單

 更新時(shí)間:2021年08月20日 11:03:31   作者:吃個(gè)石頭  
這篇文章主要為大家詳細(xì)介紹了Vue2遞歸組件實(shí)現(xiàn)樹(shù)形菜單的相關(guān)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

今天看了老長(zhǎng)時(shí)間遞歸組件,官方給的教程太簡(jiǎn)便了,根本看不出到底怎么用。于是自己查網(wǎng)摸索了一下,這兒只把核心思想寫(xiě)出來(lái)。

效果如下圖,點(diǎn)擊后打開(kāi)二級(jí)菜單,再點(diǎn)擊后打開(kāi)三級(jí)。

//js 
//引子
//思想:當(dāng)v-if=‘false'時(shí),循環(huán)時(shí)進(jìn)行的。所以一開(kāi)始就設(shè)置為false。
 ggg:{
  name:'gs',
  template:`
   <div>
     <p @click.stop='show=!show'>我是p標(biāo)簽</p> 

     //這兒show必須要初始值為false,不然就是堆棧溢出,死循環(huán)。
      <gs v-if='show' ></gs>            

    //這個(gè)是循環(huán)組件。命名后當(dāng)函數(shù)使。
   </div>         
}

由于每次遞歸組件,就相當(dāng)于實(shí)例化了一次組件。所有寫(xiě)在組件data中的值都是該組件專(zhuān)屬的。

樹(shù)狀結(jié)構(gòu):

我們?cè)诟附M件給出一個(gè)數(shù)據(jù),子組件調(diào)用這個(gè)數(shù)據(jù),然后子組件的子組件調(diào)用它父組件的數(shù)據(jù),如此循環(huán)下去。只要數(shù)據(jù)結(jié)構(gòu)相同,他們調(diào)用的方法相同,就行的通。當(dāng)最后沒(méi)有子組件的時(shí)候,
它不會(huì)報(bào)錯(cuò),這個(gè)應(yīng)該是被vue優(yōu)化了。

思想:遞歸調(diào)用某個(gè)組件,而這個(gè)組件的作用就是解析出此層的數(shù)據(jù)。因此數(shù)據(jù)的格式就有技巧:

msg:[{//對(duì)此數(shù)組遍歷。                             

 js
  text:1, //第一層數(shù)據(jù) ,要顯示1,就要對(duì)頂層text遍歷,xxx.text就得到1。
    //點(diǎn)擊‘1'彈出1-1就需要將父組件的xxx.next傳給子組件。
  next:[{
   text:'1-1',//第二層數(shù)據(jù)
   next:[{
   text:'1-1-1',//第三層數(shù)據(jù)
   next:[{
    text:'1-1-1-1',
   }]
   }]
  }]
 },{
  text:2, //第一層數(shù)據(jù)
 },{
 text:3, //第一層數(shù)據(jù)
 }]
//html
  <div>
   <ggg :msg='msg'></ggg> //這兒寫(xiě)在父組件模板中。
  </div>

//js
ggg:{
  name:'gs',// 這兒必須起個(gè)名字,這個(gè)名字其實(shí)就是構(gòu)造函數(shù)的名字。沒(méi)有名字無(wú)法遞歸組件。
  template:`// 構(gòu)造函數(shù)的return值,模板。
  <ul >  
      <li v-for='a in text'> 
   {{a.text}}//第一次1、2、3;第二次 1-1 ,第三次1-1-1,第四次1-1-1-1 
   <gs :msg='a.next'></gs> // 這兒遞歸用組件(構(gòu)造函數(shù)),代碼運(yùn)行到這兒時(shí)會(huì)返回去調(diào)用。這兒有個(gè)很重要的操作,將這一層的a.text數(shù)據(jù)傳到下一層去,并且改為text
  </li>
  </ul>`,
  props:['msg'],//這個(gè)是接收父組件過(guò)的值
}

到此基本概念已經(jīng)齊全了。

點(diǎn)擊1 出現(xiàn)1-1:

<li v-for='a in msg' @click.stop.self='show=!show'>// 在li標(biāo)簽添加一個(gè)點(diǎn)擊事件,改變show的值。
  {{a.text}}
  <gs :msg='a.next' v-if='show' ></gs>         

  //官網(wǎng)上說(shuō)了,這兒是show為true才會(huì)遞歸。就是解析下一次數(shù)據(jù)。
</li> 

點(diǎn)擊1想出現(xiàn)1-2:修改data的值,從頂層數(shù)據(jù)出現(xiàn)1 2 3可以推斷出來(lái)。

全代碼:

<template >
 <div>
 <ggg :msg='msg'></ggg> //組件使用 父組件傳msg 子組件接收(:msg)
 </div>
</template>

<script>


export default { //這兒用的腳手架,若是普通文件,這兒就是new Vue({})
 data(){
 return {
 msg:[{
  text:1,
  next:[{
   text:'1-1',
   next:[{
   text:'1-1-1',
   next:[{
    text:'1-1-1-1',
   }]
   }]
  },{
   text:'1-2' //1-2寫(xiě)在這兒,第二層數(shù)據(jù)數(shù)組中的a[1].text就是‘1-2'
  }]
  },{
  text:2,
  
  },{
  text:3,
  
  }]
 }
 },
 components:{
 ggg:{
  name:'gs',
  template:`
  <ul >
  <li v-for='a in msg' @click.stop.self='show=!show'>
   {{a.text}}
   <gs :msg='a.next' v-if='show' ></gs>
  </li>
  </ul>`,
  props:['msg'],
  data(){
  return {
   show:false
  }
  }
 }
 }
}
</script>

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

相關(guān)文章

  • 詳解vue項(xiàng)目中如何引入全局sass/less變量、function、mixin

    詳解vue項(xiàng)目中如何引入全局sass/less變量、function、mixin

    這篇文章主要介紹了詳解vue項(xiàng)目中如何引入全局sass/less變量、function、mixin,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • vue實(shí)現(xiàn)按鈕切換圖片

    vue實(shí)現(xiàn)按鈕切換圖片

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)按鈕切換圖片,正向反向以及順序切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • vue3+vite+ts使用monaco-editor編輯器的簡(jiǎn)單步驟

    vue3+vite+ts使用monaco-editor編輯器的簡(jiǎn)單步驟

    因?yàn)楫呍O(shè)需要用到代碼編輯器,根據(jù)調(diào)研,我選擇使用monaco-editor代碼編輯器,下面這篇文章主要給大家介紹了關(guān)于vue3+vite+ts使用monaco-editor編輯器的簡(jiǎn)單步驟,需要的朋友可以參考下
    2023-01-01
  • 京東 Vue3 組件庫(kù)支持小程序開(kāi)發(fā)的詳細(xì)流程

    京東 Vue3 組件庫(kù)支持小程序開(kāi)發(fā)的詳細(xì)流程

    這篇文章主要介紹了京東 Vue3 組件庫(kù)支持小程序開(kāi)發(fā)的詳細(xì)流程,通過(guò)引入NutUI,即可在項(xiàng)目中使用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-06-06
  • vue + element動(dòng)態(tài)多表頭與動(dòng)態(tài)插槽

    vue + element動(dòng)態(tài)多表頭與動(dòng)態(tài)插槽

    這篇文章主要介紹了vue + element動(dòng)態(tài)多表頭與動(dòng)態(tài)插槽,下面文章圍繞vue + element動(dòng)態(tài)多表頭與動(dòng)態(tài)插槽的相關(guān)資料展開(kāi)文章的內(nèi)容,具有一定的參考價(jià)值,需要的小伙伴可以參考一下,希望對(duì)大家有所幫助
    2021-12-12
  • vuecli3.x中輕松4步帶你使用tinymce的步驟

    vuecli3.x中輕松4步帶你使用tinymce的步驟

    這篇文章主要介紹了vuecli3.x中輕松4步帶你使用tinymce的步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • 一文詳解如何在Vue3中使用jsx/tsx

    一文詳解如何在Vue3中使用jsx/tsx

    本篇文章旨在帶領(lǐng)大家快速了解和使用?Vue?中的?JSX?語(yǔ)法,好讓大家在?Vue?中遇到或使用?JSX?的時(shí)候能很快入手,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-03-03
  • vue3-組合式api-provide/inject詳解

    vue3-組合式api-provide/inject詳解

    provide/inject 適用于跨級(jí)通信,在孫組件中通過(guò)依賴(lài)注入的方式能獲取到父組件中改變的這個(gè)值,下面通過(guò)實(shí)例代碼介紹vue3-組合式api-provide/inject的相關(guān)知識(shí),需要的朋友可以參考下
    2022-11-11
  • Vue事件獲取事件對(duì)象之event.currentTarget詳解

    Vue事件獲取事件對(duì)象之event.currentTarget詳解

    這篇文章主要介紹了Vue事件獲取事件對(duì)象之event.currentTarget,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue 路由間跳轉(zhuǎn)和新開(kāi)窗口的方式(query、params)

    Vue 路由間跳轉(zhuǎn)和新開(kāi)窗口的方式(query、params)

    這篇文章主要介紹了Vue 路由間跳轉(zhuǎn)和新開(kāi)窗口的方式,本文主要通過(guò)query方式和params方式介紹,需要的朋友可以參考下
    2019-12-12

最新評(píng)論