Example of automatic import method of vue3.0 common components

Example of automatic import method of vue3.0 common components

1. Prerequisites

We use the require.context method to import. If we use it in a project created by vite, an error "require not found" will be reported, so we must use webpack to create a project. Or someone can tell me how Vite can solve this problem.

II. Rules

The registration rule I use is to search all directories and subdirectories under the src/components/ path, search for files named "index.vue", and use the name of the parent directory as the component name for registration. The structure is as follows:

Only index.vue is registered, components with other names are not registered.

3. Registration

Since vue3.0 does not have import "Vue" from vue, we need to use app to register, so we can only do it in main.js

Entry file registration

// src/main.js

import { createApp } from 'vue'
const app = createApp(App)
//Dynamically register public components const requireComponent = require.context(
    // The relative path of its component directory is '@/components',
    // Whether to query its subdirectory true,
    // Regular expression matching the base component file name /index.vue$/
)
const jieguo = requireComponent.keys().filter((item:any)=> true)
jieguo.forEach((item:any)=>{
    const componentConfig = requireComponent(item)
    const name = item.split("/")[1]
    app.component(name,componentConfig.default || componentConfig)
})
// Registration ends app.mount('#app')

When we create, delete, or rename a public component, no registration is required. Restart the project and take a sip of water.

Summarize

This is the end of this article about automatic import of vue3.0 public components. For more relevant vue3.0 public component import content, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Vue's method of introducing all public components at one time in a concise and clear manner

<<:  Using Docker to create static website applications (multiple ways)

>>:  Instructions for using JSON operation functions in Mysql5.7

Recommend

Detailed explanation of Vue router routing

Table of contents 1. Basic use 2. Several points ...

Implementing Priority Queue in JavaScript

Table of contents 1. Introduction to priority que...

SQL implementation of LeetCode (178. Score ranking)

[LeetCode] 178.Rank Scores Write a SQL query to r...

How to create a responsive column chart using CSS Grid layout

I have been playing around with charts for a whil...

Detailed explanation of Nodejs array queue and forEach application

This article mainly records the problems and solu...

HTML+VUE paging to achieve cool IoT large screen function

Effect demo.html <html> <head> <me...

CSS navigation bar menu with small triangle implementation code

Many web pages have small triangles in their navi...

CSS specification BEM CSS and OOCSS sample code detailed explanation

Preface During project development, due to differ...

A brief discussion on spaces and blank lines in HTML code

All consecutive spaces or blank lines (newlines) ...

Writing a shell script in Ubuntu to start automatically at boot (recommended)

The purpose of writing scripts is to avoid having...

Detailed explanation of JSON.parse and JSON.stringify usage

Table of contents JSON.parse JSON.parse Syntax re...