How to make a custom global component using Vue
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!

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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

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

Hot Topics

Using Bootstrap in Vue.js is divided into five steps: Install Bootstrap. Import Bootstrap in main.js. Use the Bootstrap component directly in the template. Optional: Custom style. Optional: Use plug-ins.

You can add a function to the Vue button by binding the button in the HTML template to a method. Define the method and write function logic in the Vue instance.

The watch option in Vue.js allows developers to listen for changes in specific data. When the data changes, watch triggers a callback function to perform update views or other tasks. Its configuration options include immediate, which specifies whether to execute a callback immediately, and deep, which specifies whether to recursively listen to changes to objects or arrays.

Vue multi-page development is a way to build applications using the Vue.js framework, where the application is divided into separate pages: Code Maintenance: Splitting the application into multiple pages can make the code easier to manage and maintain. Modularity: Each page can be used as a separate module for easy reuse and replacement. Simple routing: Navigation between pages can be managed through simple routing configuration. SEO Optimization: Each page has its own URL, which helps SEO.

There are three ways to refer to JS files in Vue.js: directly specify the path using the <script> tag;; dynamic import using the mounted() lifecycle hook; and importing through the Vuex state management library.

Vue.js has four methods to return to the previous page: $router.go(-1)$router.back() uses <router-link to="/" component window.history.back(), and the method selection depends on the scene.

There are three common methods for Vue.js to traverse arrays and objects: the v-for directive is used to traverse each element and render templates; the v-bind directive can be used with v-for to dynamically set attribute values for each element; and the .map method can convert array elements into new arrays.

There are two ways to jump div elements in Vue: use Vue Router and add router-link component. Add the @click event listener and call this.$router.push() method to jump.
