Heim >Web-Frontend >View.js >Lassen Sie uns kurz die Verwendung des Menümenüs in AntDesign Vue verstehen

Lassen Sie uns kurz die Verwendung des Menümenüs in AntDesign Vue verstehen

青灯夜游
青灯夜游nach vorne
2021-12-20 11:33:135611Durchsuche

In diesem Artikel erfahren Sie, wie Sie das Menümenü in Ant Design Vue verwenden, stellen seine allgemeinen Eigenschaften und Ereignisse vor und erfahren, wie Sie mehrstufige Menüs rekursiv verschachteln. Ich hoffe, dass es für alle hilfreich ist!

Lassen Sie uns kurz die Verwendung des Menümenüs in AntDesign Vue verstehen

Version ant-design-vue: "^1.7.4",ant-design-vue: "^1.7.4",

常用属性

属性 说明 默认值
mode 菜单类型,现在支持垂直、水平、和内嵌模式三种 vertical
inlineCollapsed inline 时菜单是否收起状态
theme 主题颜色(light/dark) light
openKeys(.sync) 当前展开的 SubMenu 菜单项 key 数组
defaultOpenKeys 初始展开的 SubMenu 菜单项 key 数组
selectedKeys(v-model) 当前选中的菜单项 key 数组
defaultSelectedKeys 初始选中的菜单项 key 数组

说明
defaultSelectedKeys 是默认选中的keya-menu-item上绑定的key),被选中会有高亮的显示效果;selectedKeys 也是一样的作用,不要同时使用,区别在于如果只希望指定一个初始化的菜单选项就使用defaultSelectedKeys,如果需要通过自己修改数据来选中菜单的选中项就使用selectedKeys

openKeysdefaultOpenKeys也是同理)

常用事件

openChangeMenu的事件,SubMenu 展开/关闭的回调

递归嵌套多级菜单

若只有两级菜单则直接使用v-forv-if指令即可完成;若菜单级数≥3则需要使用函数式组件。具体原因官网已经做了说明:

Before v2.0, 因组件内部会动态更改a-sub-menu的属性,如果拆分成单文件,无法将属性挂载到a-sub-menu上,你需要自行声明属性并挂载。为了方便,避免属性的声明,我们推荐使用函数式组件。

代码
App.vue (测试就随便在App.vue里写了)

<template>
    <div id="app">
        <div style="width: 256px">
            <a-button type="primary" style="margin-bottom: 16px" @click="toggleCollapsed">
            <a-icon :type="collapsed ? &#39;menu-unfold&#39; : &#39;menu-fold&#39;" />
            </a-button>
            <a-menu
                :defaultSelectedKeys="[$route.path]"
                :openKeys="openKeys"
                mode="inline"
                theme="dark"
                :inline-collapsed="collapsed"
                @openChange="onOpenChange"
                @click="menuClick"
            >
                <template v-for="item in list">
                    <a-menu-item v-if="!item.children" :key="item.path">
                        <a-icon type="pie-chart" />
                        <span>{{ item.title }}</span>
                    </a-menu-item>
                    <sub-menu v-else :key="item.path" :menu-info="item" />
                </template>
            </a-menu>
        </div>
        <router-view/>
    </div>
</template>

<script>
import { Menu } from &#39;ant-design-vue&#39;;
const SubMenu = {
  template: `
      <a-sub-menu :key="menuInfo.key" v-bind="$props" v-on="$listeners">
        <span slot="title">
          <a-icon type="mail" /><span>{{ menuInfo.title }}</span>
        </span>
        <template v-for="item in menuInfo.children">
          <a-menu-item v-if="!item.children" :key="item.path">
            <a-icon type="pie-chart" />
            <span>{{ item.title }}</span>
          </a-menu-item>
          <sub-menu v-else :key="item.path" :menu-info="item" />
        </template>
      </a-sub-menu>
    `,
  name: &#39;SubMenu&#39;,
  // must add isSubMenu: true 此项必须被定义
  isSubMenu: true,
  props: {
    // 解构a-sub-menu的属性,也就是文章开头提到的为什么使用函数式组件
    ...Menu.SubMenu.props,
    // Cannot overlap with properties within Menu.SubMenu.props
    menuInfo: {
      type: Object,
      default: () => ({}),
    },
  },
};

export default {
    name: "App",
    components: {
        &#39;sub-menu&#39;: SubMenu,
    },
    data() {
        return {
            collapsed: false,
            openKeys: [],
            rootSubmenuKeys: [&#39;/user&#39;],
            list: [
                {
                    key: &#39;1&#39;,
                    title: &#39;信息管理&#39;,
                    path: &#39;/info&#39;,
                },
                {
                    key: &#39;2&#39;,
                    title: &#39;用户管理&#39;,
                    path: &#39;/user&#39;,
                    children: [
                        { 
                            key: &#39;2.1&#39;,
                            title: &#39;后台用户&#39;,
                            path: &#39;/adminUser&#39;,
                            children: [
                                { 
                                    key: &#39;2.1.1&#39;,
                                    title: &#39;新增用户&#39;,
                                    path: &#39;/addAdminUser&#39;,
                                    children: [
                                        {
                                            key: &#39;2.1.1。1&#39;,
                                            title: &#39;用户xx&#39;,
                                            path: &#39;/addAdminUserXX&#39;,
                                        }
                                    ]
                                }
                            ]
                        },
                        { 
                            key: &#39;2.2&#39;,
                            title: &#39;前台用户&#39;,
                            path: &#39;/frontUser&#39;,
                        }
                    ]
                }
            ],
        };
    },
    created(){
        const openKeys = window.sessionStorage.getItem(&#39;openKeys&#39;)
        if(openKeys){
            this.openKeys = JSON.parse(openKeys)
        }
    },
    methods: {
        toggleCollapsed() {
            this.collapsed = !this.collapsed;
        },
        onOpenChange(openKeys) {
            // 将当前打开的父级菜单存入缓存中
            window.sessionStorage.setItem(&#39;openKeys&#39;, JSON.stringify(openKeys))
            //  控制只打开一个
            const latestOpenKey = openKeys.find(key => this.openKeys.indexOf(key) === -1);
            if (this.rootSubmenuKeys.indexOf(latestOpenKey) === -1) {
                this.openKeys = openKeys;
            } else {
                this.openKeys = latestOpenKey ? [latestOpenKey] : [];
            }
        },
        menuClick({key}) {
            // 获取到当前的key,并且跳转
            this.$router.push({
                path: key
            })
        },
    }
};
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding: 50px;
}
</style>

这里省略了router配置,相信在座的各位也会!(不会的底下留言,包教包会!)

如果vue报编译错误You are using the runtime-only build of Vue,可以在vue的配置文件里加一行runtimeCompiler: true,重新运行即可。

如果点击同一个菜单报错了NavigationDuplicated: Avoided redundant navigation to current location,需要修改下Router设置(router/index.js

Gemeinsame Attribute

Eigenschaft Beschreibung Standardwert
Modus Menütyp unterstützt jetzt vertikale, horizontale und Inline-Modi vertikal
inlineCollapsed inline Ob das Menü geschlossen ist
Theme Designfarbe (hell/dunkel) hell code>
openKeys(.sync) Der aktuell erweiterte SubMenu-Menüpunktkey Array
defaultOpenKeys Zunächst erweiterter SubMenu Menüpunkt key Array
selectedKeys(v-model) Aktuell ausgewählter Menüpunkt key array
defaultSelectedKeys Anfänglich ausgewählter Menüpunkt key array
Beschreibung
defaultSelectedKeys ist der standardmäßig ausgewählte key (key ist an a-menu-item gebunden). Bei Auswahl wird ein hervorgehobener Anzeigeeffekt angezeigt ; selectedKeys hat den gleichen Effekt, verwenden Sie sie nicht gleichzeitig. Der Unterschied besteht darin, dass Sie defaultSelectedKeys verwenden Wenn Sie das ausgewählte Element im Menü auswählen müssen, indem Sie die Daten selbst ändern, verwenden Sie selectedKeys.

Lassen Sie uns kurz die Verwendung des Menümenüs in AntDesign Vue verstehen (Gleiches gilt für openKeys und defaultOpenKeys)

Häufige Ereignisse

openChange ist ein Ereignis von Menu, SubMenu Rückruf zum Erweitern/SchließenRekursiv verschachtelte Menüs mit mehreren Ebenen

🎜Wenn es nur Menüs mit zwei Ebenen gibt, verwenden Sie v-for und v- if Der Code>-Befehl kann abgeschlossen werden; wenn die Anzahl der Menüebenen ≥ 3 ist, müssen Sie <code>Funktionskomponente verwenden. Der konkrete Grund wurde auf der offiziellen Website erklärt: 🎜🎜🎜Vor v2.0, da die Attribute von a-sub-menu intern in der Komponente dynamisch geändert werden, wenn sie in a aufgeteilt wird In einer einzelnen Datei können die Attribute nicht gemountet werden. In a-sub-menu müssen Sie die Attribute selbst deklarieren und mounten. Der Einfachheit halber und um Eigenschaftsdeklarationen zu vermeiden, empfehlen wir die Verwendung funktionaler Komponenten. 🎜🎜Code
App.vue (Schreiben Sie den Test einfach in App.vue)🎜
const originalPush = Router.prototype.push
Router.prototype.push = function push(location) {
    return originalPush.call(this, location).catch(err => err)
}
🎜 Der router wird hier weggelassen, ich glaube, dass jeder hier das Gleiche tun wird! (Wenn Sie es nicht wissen, hinterlassen Sie bitte unten eine Nachricht, ich werde es Ihnen beibringen!) 🎜🎜🎜Wenn vue einen Kompilierungsfehler meldet, Sie verwenden den Nur-Laufzeit-Build von Vue können Sie der Konfigurationsdatei eine Zeile runtimeCompiler: true hinzufügen und sie erneut ausführen. 🎜🎜Wenn Sie auf dasselbe Menü klicken und ein Fehler NavigationDuplicated: Vermeidung redundanter Navigation zum aktuellen Standort gemeldet wird, müssen Sie die Router-Einstellungen ändern (router/index.js ): 🎜rrreee🎜Effekt🎜🎜🎜🎜🎜 Mehrstufige verschachtelte Menüs werden automatisch gerendert. Durch Klicken auf das Menü werden alle anderen erweiterten Menüs ausgeblendet. 🎜🎜【Verwandte Empfehlung: „🎜vue.js Tutorial🎜“】🎜

Das obige ist der detaillierte Inhalt vonLassen Sie uns kurz die Verwendung des Menümenüs in AntDesign Vue verstehen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen