中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vuejs怎么遞歸樹型菜單組件

發布時間:2021-04-20 13:16:07 來源:億速云 閱讀:225 作者:小新 欄目:web開發

這篇文章主要介紹了vuejs怎么遞歸樹型菜單組件,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

Vue的優點

Vue具體輕量級框架、簡單易學、雙向數據綁定、組件化、數據和結構的分離、虛擬DOM、運行速度快等優勢,Vue中頁面使用的是局部刷新,不用每次跳轉頁面都要請求所有數據和dom,可以大大提升訪問速度和用戶體驗。

遞歸組件

組件在它的模板內可以遞歸地調用自己,只有當它有 name 選項時才可以。 在官網這句話就是關鍵定義組件是一定要有name屬性。

模擬數據格式如下:

[
  {
   "id": "1",
   "menuName": "基礎管理",
   "menuCode": "10",
   "children": [
    {
     "menuName": "用戶管理",
     "menuCode": "11"
    },
    {
     "menuName": "角色管理",
     "menuCode": "12",
     "children": [
      {
       "menuName": "管理員",
       "menuCode": "121"
      },
      {
       "menuName": "CEO",
       "menuCode": "122"
      },
      {
       "menuName": "CFO",
       "menuCode": "123"
      },
      {
       "menuName": "COO",
       "menuCode": "124"
      },
      {
       "menuName": "普通人",
       "menuCode": "124"
      }
     ]
    },
    {
     "menuName": "權限管理",
     "menuCode": "13"
    }
   ]
  },
  {
   "id": "2",
   "menuName": "商品管理",
   "menuCode": ""
  },
  {
   "id": "3",
   "menuName": "訂單管理",
   "menuCode": "30",
   "children": [
    {
     "menuName": "訂單列表",
     "menuCode": "31"
    },
    {
     "menuName": "退貨列表",
     "menuCode": "32",
     "children": []
    }
   ]
  },
  {
   "id": "4",
   "menuName": "商家管理",
   "menuCode": "",
   "children": []
  }
 ]

html我們思路按照ul里面套li,無限ul套li,標題用div元素包裹,

<template>
 <li>
  <span @click="toggle">   <!-- toggle:點擊關閉展開 -->
   <i v-if="isFolder" class="icon" :class="[open ? 'folder-open' : 'folder']" @cilck="toggle"></i>
   <!-- <i v-if="isFolder" class="icon " :class="[open ? 'folder-open' : 'folder']"></i> -->
   <i v-if="!isFolder" class="icon folder-text"></i>
   {{model.menuName}}
  </span>
  <ul v-show="open" v-if="isFolder">
   <treeMenu v-for="item in model.children" :model="item"></treeMenu>
  </ul>
 </li>
</template>

官方文檔里面寫的遞歸組件強調了使用name屬性

需要注意的是,由父組件傳遞過來的數據要先進行深拷貝哦

深拷貝:把props賦值到data里,賦值的同時深拷貝一下,data里 JSON.parse(JSON.stringify(這個值就行了)),data值自己命名

export default {
  name: 'treeMenu',
  //props: ['model'], //這樣和下面效果一樣
  props: {
   model: { type: Object },
  },
  components: {},
}

按照vue的思想,不操作Dom樹,我們定義兩個變量,一個顯示隱藏子菜單(open),一個存不存子菜單修改圖標(isFolder)。

  data() {
   return {
    open: false, //一個顯示隱藏子菜單(open)
    //isFolder: true  //這個不要寫死,運用計算屬性計算看存不存在
   }
  },

利用vue計算屬性動態改變isFolder的值,修改圖標,判斷存在不子級和子級長度

  computed: {
   isFolder() { //利用vue計算屬性動態改變isFolder的值,修改圖標,判斷存在不子級和子級長度
    // return this.model.children && this.model.children.length //和下面效果一樣
    let isFolder = false
    if (this.model.children && this.model.children.length) {
     isFolder = true;
    } else {
     isFolder = false;
    }
    return isFolder
   }
  },

顯示隱藏事件

  methods: {
   toggle() {
    if (this.isFolder) {
     this.open = !this.open
    }
   }
  },

感謝你能夠認真閱讀完這篇文章,希望小編分享的“vuejs怎么遞歸樹型菜單組件”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

大邑县| 东海县| 合山市| 湄潭县| 巴塘县| 蕲春县| 扶绥县| 新沂市| 新巴尔虎左旗| 肃宁县| 左贡县| 绍兴县| 探索| 开化县| 济源市| 康定县| 呼伦贝尔市| 富川| 体育| 石林| 永川市| 清苑县| 哈巴河县| 罗甸县| 华容县| 岳阳县| 灌南县| 鄂伦春自治旗| 曲阜市| 阜阳市| 伊金霍洛旗| 营口市| 临汾市| 门源| 华池县| 武威市| 新安县| 成安县| 隆德县| 大埔县| 宁德市|