


This article brings you a brief introduction and example analysis of global registration and local registration in vue.js components. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you. help.
1. Global registration instance (the following is the code according to the example on the official website)
<div id="app"> <com-btn></com-btn> <com-btn></com-btn> </div>
<script> Vue.component('com-btn',{ data:function(){ return{ num:0, } }, template:`<button v-on:click='change'>点我{{num}}次</button>`, methods:{ change:function(){ this.num += 1; } } }) var vm = new Vue({ el:'#app', data:{ }, }) </script>
When we register a component, we need to give it a name such as com-btn. From the above code we You can see that the component name
Vue.component('my-component-name', { /* ... */ })
is the first parameter of the component com-btn we registered. This component is globally registered. After they are registered, we can use it in any newly created vue root instance. (new Vue) inside.
It is worth noting that all components must be written in front of the root instance to take effect.
2 Instances of local ancestors
<script> var childcom ={ data:function(){ return{ num:0, } }, template:`<button v-on:click='change'>点我{{num}}次</button>`, methods:{ change:function(){ this.num += 1; } } } var vm = new Vue({ el:'#app', data:{ }, components:{ 'com-btn':childcom,//调用这个组件 } }) </script>
The advantage of local registration is that when you use In a build system like webpack, if a component is registered using global registration, then when you don't use a certain component, it will still exist in the final build result, which adds unnecessary js download.
So we can register the component through a simple js object
var ComponentA = { /* ... */ }
When you need to use this component, you only need to call this defined component in your root instance. Can.
new Vue({ el: '#app' components: { 'component-a': ComponentA, 'component-b': ComponentB } })
It is worth noting that the attribute name of the root instance is components, don’t forget s. The other properties in the component are the same as those of the instance but data must be a function.
For each attribute in the components object, it is the name of the custom component, and the attribute value is the option object of this component.
Partially registered components are not available in their subcomponents. If you want componentA to be available in componentB, you need to write it like this:
var ComponentA = { /* ... */ } var ComponentB = { components: { 'component-a': ComponentA }, // ... }
Related recommendations:
Detailed explanation of vue global registration and local registration
vue component registration form
The above is the detailed content of A brief introduction and example analysis of global registration and local registration in vue.js components. For more information, please follow other related articles on the PHP Chinese website!

vue中props可以传递函数;vue中可以将字符串、数组、数字和对象作为props传递,props主要用于组件的传值,目的为了接收外面传过来的数据,语法为“export default {methods: {myFunction() {// ...}}};”。

本篇文章带大家聊聊vue指令中的修饰符,对比一下vue中的指令修饰符和dom事件中的event对象,介绍一下常用的事件修饰符,希望对大家有所帮助!

如何覆盖组件库样式?下面本篇文章给大家介绍一下React和Vue项目中优雅地覆盖组件库样式的方法,希望对大家有所帮助!

react与vue的虚拟dom没有区别;react和vue的虚拟dom都是用js对象来模拟真实DOM,用虚拟DOM的diff来最小化更新真实DOM,可以减小不必要的性能损耗,按颗粒度分为不同的类型比较同层级dom节点,进行增、删、移的操作。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Dreamweaver CS6
Visual web development tools

Zend Studio 13.0.1
Powerful PHP integrated development environment

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Atom editor mac version download
The most popular open source editor
