Maison interface Web Voir.js Comment implémenter l'affichage dynamique et la sélection de menus à plusieurs niveaux dans les projets Vue

Comment implémenter l'affichage dynamique et la sélection de menus à plusieurs niveaux dans les projets Vue

Oct 09, 2023 pm 08:54 PM
vue 多级菜单 动态展示

Comment implémenter laffichage dynamique et la sélection de menus à plusieurs niveaux dans les projets Vue

Comment réaliser l'affichage et la sélection dynamiques de menus à plusieurs niveaux dans les projets Vue

Dans les projets Vue, il est courant de réaliser les fonctions d'affichage et de sélection dynamiques des menus à plusieurs niveaux. Avec les étapes suivantes, nous pouvons réaliser cette fonctionnalité, illustrée par des exemples de code concrets.

Étape 1 : Créer des données de menu
Tout d'abord, nous devons créer des données de menu, qui contiennent la structure hiérarchique du menu, son nom et les informations de routage correspondantes. Vous pouvez utiliser un tableau pour représenter les données de menu. Chaque élément de menu est représenté par un objet. L'objet contient le nom du menu (nom), les informations de routage (chemin) et les sous-menus (éléments). Voici un exemple de données de menu :

menuData: [
  {
    name: '首页',
    path: '/home',
    items: []
  },
  {
    name: '关于我们',
    path: '/about',
    items: []
  },
  {
    name: '产品',
    path: '/products',
    items: [
      {
        name: '产品1',
        path: '/products/product1',
        items: []
      },
      {
        name: '产品2',
        path: '/products/product2',
        items: []
      }
    ]
  }
]
Copier après la connexion

Étape 2 : Créer un composant de menu
Ensuite, nous pouvons créer un composant de menu (Menu), qui est utilisé pour afficher les données de menu. Dans le modèle du composant, nous pouvons utiliser la directive v-for pour parcourir les données du menu et effectuer un affichage imbriqué selon la structure hiérarchique du menu. Afin d'obtenir l'effet de sélection du menu, nous pouvons utiliser le composant router-link et déterminer si l'élément de menu est sélectionné en fonction des informations de routage de la page actuelle. Voici un exemple de composant de menu : v-for指令对菜单数据进行遍历,并根据菜单的层级结构进行嵌套展示。为了实现选中菜单的效果,我们可以使用router-link组件,并根据当前页面的路由信息来判断菜单项是否被选中。以下是一个示例的菜单组件:

<template>
  <ul>
    <li v-for="menu in menuData" :key="menu.path">
      <router-link :to="menu.path" :class="{ active: isActive(menu) }">{{ menu.name }}</router-link>
      <menu v-if="menu.items.length" :menu-data="menu.items"></menu>
    </li>
  </ul>
</template>

<script>
export default {
  props: {
    menuData: {
      type: Array,
      required: true
    }
  },
  methods: {
    isActive(menu) {
      return this.$route.path === menu.path
    }
  }
}
</script>

<style scoped>
.active {
  font-weight: bold;
}
</style>
Copier après la connexion

步骤三:在路由配置中使用菜单组件
在路由配置文件中,我们需要将菜单组件引入,并在routes数组中使用该组件作为布局(layout)。这样,在每个页面的布局中,就可以动态展示菜单了。以下是一个示例的路由配置:

import Vue from 'vue'
import Router from 'vue-router'
import Menu from '@/components/Menu'

Vue.use(Router)

const routes = [
  {
    path: '/',
    name: 'Home',
    component: Menu,
    children: [
      {
        path: 'home',
        component: () => import('@/views/Home')
      },
      {
        path: 'about',
        component: () => import('@/views/About')
      },
      {
        path: 'products',
        component: () => import('@/views/Products'),
        children: [
          {
            path: 'product1',
            component: () => import('@/views/Product1')
          },
          {
            path: 'product2',
            component: () => import('@/views/Product2')
          }
        ]
      }
    ]
  }
]

const router = new Router({
  mode: 'history',
  base: process.env.BASE_URL,
  routes
})

export default router
Copier après la connexion

通过以上三个步骤,我们就可以在Vue项目中实现多级菜单的动态展示和选中功能了。在菜单组件中,使用v-for进行菜单数据的遍历,使用router-linkrrreee

Étape 3 : Utiliser le composant de menu dans la configuration de routage

Dans le fichier de configuration de routage, nous devons introduire le composant de menu et utiliser le composant dans les routes tableau Comme mise en page. De cette manière, le menu peut être affiché dynamiquement dans la mise en page de chaque page. Voici un exemple de configuration de routage :

rrreee🎜Grâce aux trois étapes ci-dessus, nous pouvons implémenter la fonction d'affichage et de sélection dynamique des menus à plusieurs niveaux dans le projet Vue. Dans le composant de menu, utilisez v-for pour parcourir les données de menu, utilisez le composant router-link pour effectuer des sauts de routage et déterminez si l'élément de menu est sélectionné en fonction de les informations de routage de la page actuelle. Sélectionnez et contrôlez l'effet du menu sélectionné à travers les styles. 🎜🎜J'espère que le contenu ci-dessus vous sera utile, si vous avez des questions, n'hésitez pas à me les poser. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser Bootstrap en Vue Comment utiliser Bootstrap en Vue Apr 07, 2025 pm 11:33 PM

L'utilisation de bootstrap dans vue.js est divisée en cinq étapes: installer bootstrap. Importer un bootstrap dans main.js. Utilisez le composant bootstrap directement dans le modèle. Facultatif: style personnalisé. Facultatif: utilisez des plug-ins.

Comment ajouter des fonctions aux boutons pour Vue Comment ajouter des fonctions aux boutons pour Vue Apr 08, 2025 am 08:51 AM

Vous pouvez ajouter une fonction au bouton VUE en liant le bouton dans le modèle HTML à une méthode. Définissez la logique de la fonction de méthode et d'écriture dans l'instance Vue.

Comment référencer le fichier JS avec Vue.js Comment référencer le fichier JS avec Vue.js Apr 07, 2025 pm 11:27 PM

Il existe trois façons de se référer aux fichiers JS dans Vue.js: spécifiez directement le chemin à l'aide du & lt; script & gt; étiqueter;; importation dynamique à l'aide du crochet de cycle de vie monté (); et l'importation via la bibliothèque de gestion de l'État Vuex.

Comment utiliser Watch in Vue Comment utiliser Watch in Vue Apr 07, 2025 pm 11:36 PM

L'option Watch dans Vue.js permet aux développeurs d'écouter des modifications de données spécifiques. Lorsque les données changent, regardez déclenche une fonction de rappel pour effectuer des vues de mise à jour ou d'autres tâches. Ses options de configuration incluent immédiatement, qui spécifie s'il faut exécuter un rappel immédiatement, et profond, ce qui spécifie s'il faut écouter récursivement les modifications des objets ou des tableaux.

Que signifie le développement de plusieurs pages Vue? Que signifie le développement de plusieurs pages Vue? Apr 07, 2025 pm 11:57 PM

Le développement multi-pages VUE est un moyen de créer des applications à l'aide du cadre Vue.js, où l'application est divisée en pages distinctes: Maintenance du code: La division de l'application en plusieurs pages peut rendre le code plus facile à gérer et à maintenir. Modularité: chaque page peut être utilisée comme module séparé pour une réutilisation et un remplacement faciles. Routage simple: la navigation entre les pages peut être gérée par une configuration de routage simple. Optimisation du référencement: chaque page a sa propre URL, ce qui aide le référencement.

Comment revenir à la page précédente par Vue Comment revenir à la page précédente par Vue Apr 07, 2025 pm 11:30 PM

Vue.js dispose de quatre méthodes pour revenir à la page précédente: $ router.go (-1) $ router.back () utilise & lt; router-link to = & quot; / & quot; Composant Window.History.back (), et la sélection de la méthode dépend de la scène.

Comment utiliser Vue Traversal Comment utiliser Vue Traversal Apr 07, 2025 pm 11:48 PM

Il existe trois méthodes courantes pour que Vue.js traverse les tableaux et les objets: la directive V-FOR est utilisée pour traverser chaque élément et les modèles de rendu; La directive V-Bind peut être utilisée avec V-FOR pour définir dynamiquement les valeurs d'attribut pour chaque élément; et la méthode .map peut convertir les éléments du tableau en nouveaux tableaux.

Comment interroger la version de Vue Comment interroger la version de Vue Apr 07, 2025 pm 11:24 PM

Vous pouvez interroger la version Vue en utilisant Vue Devtools pour afficher l'onglet Vue dans la console du navigateur. Utilisez NPM pour exécuter la commande "NPM List -g Vue". Recherchez l'élément VUE dans l'objet "dépendances" du fichier package.json. Pour les projets Vue CLI, exécutez la commande "Vue --version". Vérifiez les informations de la version dans le & lt; script & gt; Tag dans le fichier html qui fait référence au fichier VUE.

See all articles