I have studied Vue.js in the past two days and I feel that there is a lot of knowledge about components and it is very important, so this article mainly introduces you to the implementation method of custom global components in Vue. It is introduced through sample code. It is very detailed and has certain reference learning value for everyone to learn or use vue. Friends who need it can follow the editor to learn together.
Preface
#Sometimes when we are doing development, we want to write a plug-in ourselves and then we can use our own plug-in, that kind of There is a strong sense of accomplishment. Today I solved a problem that has been bothering me for a long time. I will record it now for future reference.
The knowledge point involved is the use of plug-ins in the Vue.js official website tutorial.
The method is as follows:
First of all, I encountered The problem is that if my custom component needs to be called multiple times in other components in the project, my previous solution is simply to reference it wherever it is needed. This undoubtedly adds a lot of code duplication.
When using some UI frameworks of Vue.js, I noticed that you only need to import the plug-in in the project's entry file and then follow Vue.use('plugin name'). In this way, the components and methods in this framework can be used throughout the project.
After consulting the information, I found that the custom component needs to provide an install method
import sideblockComponent from './sideBlock' const defaultComponentName = 'sidebar' const Sidebar = { install(Vue, options = {}) { const componentName = options.componentName || defaultComponentName //提供可选的组件名 Vue.component(componentName, sideblockComponent) } } export default Sidebar
Introduce the component you wrote like this, then create an object and include an install method, and useVue.component()
The method is registered as a Vue global component, and finally export default exports this object.
Now that the most critical step has been completed, the next step is the most critical step.
We need to introduce the just-made component into the project's entry file, and use the plug-in through Vue.use
(introduced component).
At this point, a global Vue component is ready. While we provide the install method, we can also trigger the methods in the component through the Vue.$emit()
method. However, recently when using Element UI, we found that the methods in their components are generally through Vue.$refs()
to trigger. The specific reasons will be left for future research.
Basic usage of vue $refs
<p id="app"> <input type="text" ref="input1"/> <button @click="add">添加</button> </p>
<script> new Vue({ el: "#app", methods:{ add:function(){ this.$refs.input1.value ="22"; //this.$refs.input1 减少获取dom节点的消耗 } } }) </script>
Generally speaking, to obtain DOM elements, document.querySelector (".input1") is required to obtain them This dom node then gets the value of input1.
But after binding with ref, we no longer need to obtain the dom node. We can directly bind input1 to the above input and then call it in $refs.
Then call this in javascript: this.$refs.input1 This will reduce the consumption of obtaining dom nodes
The above is what I compiled for everyone. I hope it will be helpful to everyone in the future. .
Related articles:
Using axios to upload files in vue
How to use gulp to create a complete project process
How to add an array to an object in js
The above is the detailed content of How to make a custom global component using Vue. 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

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

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 English version
Recommended: Win version, supports code prompts!

Dreamweaver CS6
Visual web development tools

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