亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

開發(fā)Vue樹形組件的示例代碼

 更新時(shí)間:2017年12月21日 09:27:55   作者:stonefisher  
本篇文章主要介紹了開發(fā)Vue樹形組件的示例代碼,它展現(xiàn)了組件的遞歸使用。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

本文介紹了Vue樹形組件的示例代碼,分享給大家,具體如下:

使用SemanticUI和vue做一個(gè)menubar組件,實(shí)現(xiàn)方法大概是這樣的:

<template> 
  <div class="ui menu"> 
   <template v-for="item in leftItems"> 
    <a " v-if="!item.children" @click="item.click"> 
     <i class="{{ item.icon }} icon" v-if="item.icon"></i>{{item.text}} 
     <div class="ui mini {{item.labelColor }} label" v-if="item.label"> 
      {{item.label}} 
     </div> 
    </a>  
   //如果有有children則說明是下拉菜單項(xiàng),然后遞歸調(diào)用自身 
    <template v-else="item.children.length > 0"> 
     <div class="ui dropdown item"> 
      <i class="{{ item.icon }} icon" v-if="item.icon"></i>   
      <div class="text"> {{item.text}}</div> 
      <menubar :items="item.children" ></menubar> 
     </div> 
    </template> 
   </template> 
  //顯示在右側(cè)的菜單項(xiàng),也是遞歸調(diào)用自身 
   <menubar :items="rightItems" v-if="rightItems.length > 0"></menubar> 
  </div> 
</template> 

使用時(shí),假如父組件app使用到了menubar組件,那么data中需要定義一下items數(shù)據(jù),例 :

menubar:[ 
     {id:"a",text:"主頁1",icon:"home",tips:"提示",label:"33",labelColor:"red",url:"#"}, 
     {id:"b",text:"菜單",icon:"edit",tips:"提示",url:"#",children:[ 
       {id:"a",text:"菜單1",click:"test3",icon:"home",url:"#"}, 
       {id:"a",text:"菜單2",click:"test3",icon:"home",url:"#"} 
     ]}, 
     {id:"bb",text:"編輯",tab:"a",icon:"user",vlink:"#"}, 
     {id:"bb",text:"文件",tab:"b",icon:"user",click:"test1"}, 
     {id:"bb",text:"幫助",tab:"c",icon:"help",click:"test2"}, 
     {id:"bb",text:"工具",icon:"user",url:"www.baidu.com"}, 
     {id:"c",text:"設(shè)置",icon:"home",tips:"提示",enabled:true,color:"blue",url:"#",right:true,label:"",children:[ 
        {id:"bbb",text:"配置",icon:"home",tips:"提示",click:"test3"}, 
        {id:"adsd",text:"退出",icon:"home",tips:"提示",vlink:"/workdesk",url:"#"} 
        ] 
      } 
   ] 

里面的click事件是定義了,當(dāng)在工具欄中單擊時(shí)的事件,理想的情況應(yīng)該是事件定義在父組件app的events里面,像這樣:

events:{ 
  eventa:function(){....}, 
  eventb:function(){....}, 
} 

工具欄組件是根據(jù)傳入的items來生成的,包括里面的子組件。最終工具欄組件的結(jié)構(gòu)就是一個(gè)樹狀結(jié)構(gòu),例似這樣的:

MenuBar
--MenuBar                   
----MenuBar
-----MenuBar
--Menubar

由于每個(gè)工具欄組件里面的每個(gè)Menubar均有自己的上下文,這樣當(dāng)子組件Menubar的click事件觸發(fā)時(shí)并不會(huì)調(diào)用到頂層app組件events里面定義的事件,而只是調(diào)用了父Menubar的events事件。

但是在使用體驗(yàn)上,很明顯,工具欄組件的點(diǎn)擊事件定義應(yīng)該是定義在app組件的events里面的才是合理。我們希望menubar:[]定義菜單項(xiàng)時(shí),不管多少級(jí)嵌套,事件的觸發(fā)均可以冒泡到最上面的menubar的父上面。
因此,要實(shí)現(xiàn)該機(jī)制,目前是采用組件之間的通訊機(jī)制來實(shí)現(xiàn)的:

<a @click="onMenuItemClick(item,$event)" data-tab="{{item.tab}}" v-link="item.vlink" href="{{item.url}}" rel="external nofollow" v-if="!item.children" :class="[{'active':item.active==true,'disabled':item.enabled==false},item.color,'item']" title="{{item.tips}}"> 
     <i class="{{ item.icon }} icon" v-if="item.icon"></i>{{item.text}} 
     <div class="ui mini {{item.labelColor }} label" v-if="item.label"> 
      {{item.label}} 
     </div> 
    </a> 

上面定義一個(gè)事件@click="onMenuItemClick(item,$event)"

methods:{ 
  onMenuItemClick:function(item,$event){    
   if(this.subMenu){ 
    this.$dispatch("menuItemClick",item,$event)  
   }else{ 
    if(item.click){ 
     this.$parent.$emit(item.click,item) 
    } 
   }   
  } 
 } 

在onMenuItemClick觸發(fā)時(shí),我們根據(jù)傳入的subMenu來確認(rèn)點(diǎn)擊事件如何處理,如果Menubar是作為子菜單欄處理,則我們就直接向上冒泡事件,否則就在上層父組件觸發(fā)事件。

復(fù)制代碼 代碼如下:
<menubar  @menuItemClick="onMenuItemClick" :items="rightItems" sub-menu="true" v-if="rightItems.length > 0"></menubar>

在menubar組件內(nèi)部調(diào)用時(shí)就傳入submenu=true,并且偵聽事件menuItemClick,menuItemClick事件代碼這樣:

events:{ 
  menuItemClick:function(item,$event){ 
   if(!this.subMenu){ 
    this.$parent.$emit(item.click,item) 
   }else{ 
    return true 
   } 
  } 
 }, 

小結(jié)一下:

在處理嵌套結(jié)構(gòu)的組件,如具有下拉菜單的工具欄、樹形組件等時(shí),由于組件內(nèi)部均具有各自獨(dú)立的上下文,因此必須使用組件通訊機(jī)制來處理內(nèi)部組件間的通訊。

但如此處理方式,我覺得還是比較麻煩的,理想的方式,我覺得最好的官方可以為組件提供一個(gè)直接使用父組件上下文的機(jī)制,例如:

<MenuBar> 
 <button scoped="false"></button> 
<button scoped="false"></button> 
</MenuBar> 

這樣上面的button就沒有自己的上下文,而可以直接引入父組件的上下文,這樣模式應(yīng)該在很多場合均會(huì)使用到的。

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

相關(guān)文章

  • Vue用v-for給src屬性賦值的方法

    Vue用v-for給src屬性賦值的方法

    下面小編就為大家分享一篇Vue用v-for給src屬性賦值的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • Vue實(shí)現(xiàn)選擇城市功能

    Vue實(shí)現(xiàn)選擇城市功能

    這篇文章主要介紹了Vue實(shí)現(xiàn)選擇城市功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-05-05
  • Vue?mergeProps用法詳細(xì)講解

    Vue?mergeProps用法詳細(xì)講解

    這篇文章主要介紹了Vue?mergeProps用法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-10-10
  • vue swipeCell滑動(dòng)單元格(仿微信)的實(shí)現(xiàn)示例

    vue swipeCell滑動(dòng)單元格(仿微信)的實(shí)現(xiàn)示例

    這篇文章主要介紹了vue swipeCell滑動(dòng)單元格(仿微信)的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • Ant Design Vue resetFields表單重置不生效問題及解決

    Ant Design Vue resetFields表單重置不生效問題及解決

    這篇文章主要介紹了Ant Design Vue resetFields 表單重置不生效問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • vue-cli3使用 DllPlugin 實(shí)現(xiàn)預(yù)編譯提升構(gòu)建速度

    vue-cli3使用 DllPlugin 實(shí)現(xiàn)預(yù)編譯提升構(gòu)建速度

    這篇文章主要介紹了vue-cli3使用 DllPlugin 實(shí)現(xiàn)預(yù)編譯提升構(gòu)建速度 ,需要的朋友可以參考下
    2019-04-04
  • vue項(xiàng)目打包后,由于html被緩存導(dǎo)致出現(xiàn)白屏的處理方案

    vue項(xiàng)目打包后,由于html被緩存導(dǎo)致出現(xiàn)白屏的處理方案

    這篇文章主要介紹了vue項(xiàng)目打包后,由于html被緩存導(dǎo)致出現(xiàn)白屏的處理方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Vue中的 DOM與Diff詳情

    Vue中的 DOM與Diff詳情

    這篇文章主要介紹了Vue中的 DOM與Diff詳情,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助
    2022-08-08
  • vue 對(duì)axios get pust put delete封裝的實(shí)例代碼

    vue 對(duì)axios get pust put delete封裝的實(shí)例代碼

    在本篇文章里我們給各位整理的是一篇關(guān)于vue 對(duì)axios get pust put delete封裝的實(shí)例代碼內(nèi)容,有需要的朋友們可以參考下。
    2020-01-01
  • 詳解vuex的簡單todolist例子

    詳解vuex的簡單todolist例子

    這篇文章主要介紹了詳解vuex的簡單todolist例子,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07

最新評(píng)論