Maison interface Web Voir.js Interpréter la fonction Vue.component et ses scénarios d'application dans Vue

Interpréter la fonction Vue.component et ses scénarios d'application dans Vue

Jul 26, 2023 am 09:09 AM
vuecomponent - vue组件 解读 - 解析 应用场景 - 使用场景

Interprétation de la fonction Vue.component et de ses scénarios d'application dans Vue

Vue est un framework JavaScript populaire et un framework progressif pour la création d'interfaces utilisateur. Vue utilise la modularisation pour diviser l'interface en parties indépendantes et réutilisables, ce qui améliore considérablement la maintenabilité et la réutilisation du code. Parmi elles, la fonction Vue.component est une méthode très importante dans le framework Vue, utilisée pour enregistrer les composants globaux. Cet article fournira une explication détaillée des scénarios d'utilisation et d'application de la fonction Vue.component et fournira des exemples de code.

La syntaxe de base de la fonction Vue.component est la suivante :

Vue.component('componentName', {
  // 组件的配置选项
  // 可以包括 props, data, methods, computed 等等
  template: '<div>...</div>'
})
Copier après la connexion

où, 'componentName' est le nom du composant, à travers lequel le composant peut être utilisé dans le modèle. Les options de configuration sont un objet qui peut contenir des configurations liées aux composants, telles que des accessoires, des données, des méthodes, des calculs, etc. Le modèle est le modèle du composant, qui est utilisé pour restituer le contenu du composant.

Les composants enregistrés à l'aide de la fonction Vue.component sont disponibles dans le monde entier et peuvent être utilisés n'importe où dans le projet. Ensuite, nous discutons de plusieurs scénarios d'application courants des fonctions Vue.component.

  1. Composants de mise en page

Pendant le développement, nous rencontrons souvent certains composants de mise en page qui doivent être utilisés à plusieurs reprises, tels que la barre de navigation supérieure, le pied de page inférieur, le menu latéral, etc. Ces composants de mise en page peuvent être enregistrés en tant que composants globaux à l'aide de la fonction Vue.component, qui peut être utilisée directement dans n'importe quelle page du projet, ce qui est très pratique.

Vue.component('header', {
  template: '<div>这是顶部导航栏</div>'
})

Vue.component('footer', {
  template: '<div>这是底部页脚</div>'
})

Vue.component('sidebar', {
  template: '<div>这是侧边菜单栏</div>'
})
Copier après la connexion

Lorsque vous utilisez des composants de mise en page, il vous suffit d'ajouter les balises correspondantes dans le modèle :

<template>
  <div>
    <header></header>
    <div>页面内容</div>
    <footer></footer>
  </div>
</template>
Copier après la connexion
  1. Bibliothèque de composants d'interface utilisateur

La fonction Vue.component peut également être utilisée pour créer une bibliothèque de composants d'interface utilisateur personnalisée. En enregistrant les composants de l'interface utilisateur en tant que composants globaux, nous pouvons utiliser ces composants librement tout au long du projet et fournir un style d'interface utilisateur cohérent.

// 自定义的UI组件
Vue.component('button', {
  template: '<button class="custom-button"><slot></slot></button>'
})

Vue.component('dialog', {
  template: `
    <div class="custom-dialog">
      <h3>{{ title }}</h3>
      <div>{{ content }}</div>
      <button @click="close">关闭</button>
    </div>
  `,
  props: {
    title: {
      type: String,
      required: true
    },
    content: {
      type: String,
      required: true
    }
  },
  methods: {
    close() {
      // 关闭弹窗的逻辑
    }
  }
})
Copier après la connexion

Lors de l'utilisation de ces composants d'interface utilisateur personnalisés, il vous suffit d'utiliser les balises correspondantes :

<template>
  <div>
    <button>点击我</button>
    
    <dialog title="提示" content="这是一个对话框"></dialog>
  </div>
</template>
Copier après la connexion
  1. Composants dynamiques

Les composants créés via la fonction Vue.component sont statiques, c'est-à-dire pendant la phase d'enregistrement du composant. Le contenu et le comportement du composant sont déterminés. Cependant, dans certains cas, nous devons charger des composants de manière dynamique, par exemple en affichant différents composants en fonction des opérations de l'utilisateur ou en générant dynamiquement des composants en fonction des données d'arrière-plan. Dans ce cas, vous pouvez utiliser la balise <component> de Vue combinée à la fonction Vue.component.

&lt;template&gt;
  &lt;div&gt;
    &lt;component :is=&quot;currentComponent&quot;&gt;&lt;/component&gt;
    
    &lt;button @click=&quot;switchComponent&quot;&gt;切换组件&lt;/button&gt;
  &lt;/div&gt;
&lt;/template&gt;

&lt;script&gt;
  export default {
    data() {
      return {
        currentComponent: 'ComponentA'
      }
    },
    methods: {
      switchComponent() {
        if (this.currentComponent === 'ComponentA') {
          this.currentComponent = 'ComponentB'
        } else {
          this.currentComponent = 'ComponentA'
        }
      }
    },
    components: {
      ComponentA: {
        template: '&lt;div&gt;组件A&lt;/div&gt;'
      },
      ComponentB: {
        template: '&lt;div&gt;组件B&lt;/div&gt;'
      }
    }
  }
&lt;/script&gt;
Copier après la connexion

Dans le code ci-dessus, l'attribut is de la balise <component> est lié à une variable currentComponent, qui change dynamiquement de composants en fonction de la valeur de currentComponent. Grâce à la fonction Vue.component, nous pouvons enregistrer les deux composants ComponentA et ComponentB et les utiliser dans la balise <component>

Résumé :

La fonction Vue.component est une méthode très importante dans le framework Vue, utilisée pour enregistrer des composants globaux. Grâce à cette fonction, nous pouvons facilement créer une variété de composants et les réutiliser dans le projet. Cet article présente la syntaxe de base de la fonction Vue.component et ses scénarios d'application dans Vue, y compris les composants de mise en page, les bibliothèques de composants d'interface utilisateur et les composants dynamiques. J'espère que les exemples de code et les interprétations de cet article pourront aider les lecteurs à mieux comprendre et appliquer la fonction Vue.component.

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

Article chaud

Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

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)

Qu'est-ce que Vuex et comment l'utiliser pour la gestion de l'État dans les applications VUE? Qu'est-ce que Vuex et comment l'utiliser pour la gestion de l'État dans les applications VUE? Mar 11, 2025 pm 07:23 PM

Qu'est-ce que Vuex et comment l'utiliser pour la gestion de l'État dans les applications VUE?

Comment configurer la montre du composant dans Vue Export Default Comment configurer la montre du composant dans Vue Export Default Mar 04, 2025 pm 03:30 PM

Comment configurer la montre du composant dans Vue Export Default

Quelles sont les principales caractéristiques de Vue.js (architecture basée sur les composants, DOM virtuel, liaison réactive des données)? Quelles sont les principales caractéristiques de Vue.js (architecture basée sur les composants, DOM virtuel, liaison réactive des données)? Mar 14, 2025 pm 07:05 PM

Quelles sont les principales caractéristiques de Vue.js (architecture basée sur les composants, DOM virtuel, liaison réactive des données)?

Comment implémenter des techniques de routage avancées avec le routeur VUE (routes dynamiques, routes imbriquées, gardes de route)? Comment implémenter des techniques de routage avancées avec le routeur VUE (routes dynamiques, routes imbriquées, gardes de route)? Mar 11, 2025 pm 07:22 PM

Comment implémenter des techniques de routage avancées avec le routeur VUE (routes dynamiques, routes imbriquées, gardes de route)?

Comment créer et utiliser des plugins personnalisés dans vue.js? Comment créer et utiliser des plugins personnalisés dans vue.js? Mar 14, 2025 pm 07:07 PM

Comment créer et utiliser des plugins personnalisés dans vue.js?

Qu'est-ce que le routeur Vue et comment l'utiliser pour la navigation d'application à une seule page (SPA)? Qu'est-ce que le routeur Vue et comment l'utiliser pour la navigation d'application à une seule page (SPA)? Mar 11, 2025 pm 07:21 PM

Qu'est-ce que le routeur Vue et comment l'utiliser pour la navigation d'application à une seule page (SPA)?

Comment configurer VUE CLI pour utiliser différentes cibles de construction (développement, production)? Comment configurer VUE CLI pour utiliser différentes cibles de construction (développement, production)? Mar 18, 2025 pm 12:34 PM

Comment configurer VUE CLI pour utiliser différentes cibles de construction (développement, production)?

Comment utiliser Vue avec Docker pour le déploiement conteneurisé? Comment utiliser Vue avec Docker pour le déploiement conteneurisé? Mar 14, 2025 pm 07:00 PM

Comment utiliser Vue avec Docker pour le déploiement conteneurisé?

See all articles