欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3全局組件自動(dòng)注冊(cè)功能實(shí)現(xiàn)

 更新時(shí)間:2023年02月01日 15:45:45   作者:風(fēng)啞  
本文主要講述vue3的全局公共組件的自動(dòng)注冊(cè)功能,本文分步驟結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧

vue3全局組件自動(dòng)注冊(cè)

前言:

本文主要講述vue3的全局公共組件的自動(dòng)注冊(cè)

第一步:建文件

需要在src/components 下創(chuàng)建一個(gè)文件夾用于存放封裝的公共組件(這里我起名叫coms)

需要在src/components 下創(chuàng)建一個(gè)js文件用于存放引入組件并注冊(cè)(這里我起名叫Index.js)

第二步:寫(xiě)函數(shù)

在coms中建文件夾,將組件放入這個(gè)文件夾,此文件夾的名字就是我們將要注冊(cè)組件的名字。

在Index.js中寫(xiě)入以下工具函數(shù):

// 全局組件注冊(cè) 需要到coms這個(gè)目錄下注冊(cè)
 
export default {
    install(app) {
        const req = require.context('./coms', true, /\.vue$/);
        req.keys().forEach((item) => {
            const defaultObj = req(item).default;
 
            let name = item.split('/')[1];
            // console.log('name', name);
            app.component(name, defaultObj);
        });
    }
};

注意:這里我沒(méi)有用 defaultObj.__file 來(lái)取文件路徑,是因?yàn)樯a(chǎn)環(huán)境下__file屬性會(huì)被刪除,會(huì)導(dǎo)致如下報(bào)錯(cuò)

第三步:導(dǎo)入文件

在main.js中導(dǎo)入工具函數(shù)并掛載到app中

import coms from '@/components/Index'; //全局組件注冊(cè)
app.use(coms);

第四步:全局使用

到這一步就可以全局用我們定義好的文件名作為組件名了。

ps:vue2其實(shí)也大差不差,就是吧app.use()改成了 Vue.use()

最后感謝大佬的指導(dǎo) @一個(gè)好好的程序員

參考文獻(xiàn):

vue3全局組件注冊(cè)

補(bǔ)充: Vue3注冊(cè)全局組件

例如組件使用頻率非常高,幾乎每個(gè)頁(yè)面都在使用便可以封裝成全局組件

1.注冊(cè)單個(gè)全局組件

在main.ts 引入我們的組件跟隨在createApp(App) 后面 切記不能放到mount 后面這是一個(gè)鏈?zhǔn)秸{(diào)用用

其次調(diào)用 component 第一個(gè)參數(shù)組件名稱 第二個(gè)參數(shù)組件實(shí)例

import { createApp } from 'vue'
import App from './App.vue'
import './assets/css/reset/index.less'
import Card from './components/Card/index.vue'
createApp(App).component('Card',Card).mount('#app') 
//.component('Card',Card)就是注冊(cè)全局組件 (‘自定義鍵名',組件名)

使用方法

直接在其他vue頁(yè)面 立即使用即可 無(wú)需引入

<template>
 <Card></Card>
</template>

2.批量注冊(cè)全局組件

遇到要注冊(cè)很多個(gè)全局組件時(shí),可以定義中間件,讓中間件去完成組件注冊(cè),然后main.js再引入使用這個(gè)中間件

src/components中新建index.ts用來(lái)將所有需要全局注冊(cè)的組件導(dǎo)入

?: 如果使用的是 JS 可以刪除類型校驗(yàn)

import type { Component } from 'vue' //import type 是用來(lái)協(xié)助進(jìn)行類型檢查和聲明的,在運(yùn)行時(shí)是完全不存在的。

import SvgIcon from './SvgIcon/index.vue'

// ?如果使用的是 JS 可以刪除類型校驗(yàn)

const components: {

  [propName: string]: Component //字面量類型,每個(gè)屬性值類型為組件的類型

} = {

  SvgIcon

}

export default components

2. 在main.ts中導(dǎo)入

?這里使用循環(huán)的方式, 將每個(gè)全局組件進(jìn)行注冊(cè)

import { createApp } from 'vue'

import ElementPlus from 'element-plus'

import 'element-plus/dist/index.css' // 基于斷點(diǎn)的隱藏類 Element 額外提供了一系列類名,用于在某些條件下隱藏元素

import App from './App.vue'

import router from './router'

import { store, key } from './store'

import globalComponent from '@/components/index' //引入需要注冊(cè)的全部組件

const app = createApp(App)

app.use(store, key).use(router).use(ElementPlus)

// 注冊(cè)全局的組件 (對(duì)所有需要注冊(cè)的組件進(jìn)行遍歷并注冊(cè))

for (const componentItme in globalComponent) {

  app.component(componentItme, globalComponent[componentItme])

}

app.mount('#app') //需要注冊(cè)完組件后才掛載

3. 如果使用TS編寫(xiě),還需要在和main.ts同級(jí)的目錄, 創(chuàng)建一個(gè)components.d.ts, 用來(lái)處理組件引入報(bào)錯(cuò)的問(wèn)題和添加組件類型提示

import SvgIcon from '@/components/SvgIcon/index.vue'

//要擴(kuò)充@vue/runtime-core包的聲明

declare module '@vue/runtime-core' {

  export interface GlobalComponents { //這里擴(kuò)充"ComponentCustomProperties"接口

    SvgIcon: typeof SvgIcon

  }

}

4. 最后直接導(dǎo)入即可

到此這篇關(guān)于vue3全局組件自動(dòng)注冊(cè)功能實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)vue3全局組件自動(dòng)注冊(cè)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue3 全局使用按鈕截流指令示例代碼

    Vue3 全局使用按鈕截流指令示例代碼

    這篇文章主要介紹了Vue3 全局使用按鈕截流指令示例代碼,Vue2與Vue3中的自定義指令實(shí)現(xiàn)方式略有不同,但實(shí)現(xiàn)的按鈕截流功能是類似的,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • vue一步到位的實(shí)現(xiàn)動(dòng)態(tài)路由

    vue一步到位的實(shí)現(xiàn)動(dòng)態(tài)路由

    這篇文章主要介紹了vue一步到位的實(shí)現(xiàn)動(dòng)態(tài)路由,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Vue循環(huán)遍歷選項(xiàng)賦值到對(duì)應(yīng)控件的實(shí)現(xiàn)方法

    Vue循環(huán)遍歷選項(xiàng)賦值到對(duì)應(yīng)控件的實(shí)現(xiàn)方法

    這篇文章主要介紹了Vue-循環(huán)遍歷選項(xiàng)賦值到對(duì)應(yīng)控件的實(shí)現(xiàn)方法啊,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • vue 解決報(bào)錯(cuò)問(wèn)題小結(jié)

    vue 解決報(bào)錯(cuò)問(wèn)題小結(jié)

    最近入門(mén)vue,用字節(jié)跳動(dòng)的arco初始化一個(gè)項(xiàng)目的時(shí)候報(bào)錯(cuò)自己解決后沒(méi)來(lái)的及截圖,從別人那拷貝個(gè)網(wǎng)圖把,是一樣的報(bào)錯(cuò),本文給大家分享vue 解決報(bào)錯(cuò)問(wèn)題小結(jié),感興趣的朋友一起看看吧
    2023-09-09
  • vue前端開(kāi)發(fā)keepAlive使用詳解

    vue前端開(kāi)發(fā)keepAlive使用詳解

    在開(kāi)發(fā)中經(jīng)常有從列表跳到詳情頁(yè),然后返回詳情頁(yè)的時(shí)候需要緩存列表頁(yè)的狀態(tài)(比如滾動(dòng)位置信息),這個(gè)時(shí)候就需要保存狀態(tài),要緩存狀態(tài)
    2021-10-10
  • Vuejs入門(mén)教程之Vue生命周期,數(shù)據(jù),手動(dòng)掛載,指令,過(guò)濾器

    Vuejs入門(mén)教程之Vue生命周期,數(shù)據(jù),手動(dòng)掛載,指令,過(guò)濾器

    本篇文章主要介紹了Vuejs入門(mén)教程之Vue生命周期,數(shù)據(jù),手動(dòng)掛載,指令,過(guò)濾器的相關(guān)知識(shí)。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧
    2017-04-04
  • 一篇超完整的Vue新手入門(mén)指導(dǎo)教程

    一篇超完整的Vue新手入門(mén)指導(dǎo)教程

    這篇文章主要給大家介紹了關(guān)于Vue入門(mén)的相關(guān)資料,是一篇超完整的Vue入門(mén)教程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • ElementPlus 中el-select自定義指令實(shí)現(xiàn)觸底加載請(qǐng)求options數(shù)據(jù)的方法

    ElementPlus 中el-select自定義指令實(shí)現(xiàn)觸底加載請(qǐng)求options數(shù)據(jù)的方法

    觸底時(shí),繼續(xù)向后端發(fā)請(qǐng)求獲取下一頁(yè)的數(shù)據(jù),請(qǐng)求回來(lái)的數(shù)據(jù)合并給options,這篇文章主要介紹了ElementPlus 中el-select自定義指令實(shí)現(xiàn)觸底加載請(qǐng)求options數(shù)據(jù)的操作方法,需要的朋友可以參考下
    2024-08-08
  • Vue表單輸入綁定的示例代碼

    Vue表單輸入綁定的示例代碼

    這篇文章主要介紹了Vue表單輸入綁定的示例代碼,本文使用v-model指令在表單input創(chuàng)建雙向數(shù)據(jù)綁定,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-11-11
  • 使用vue編寫(xiě)h5公眾號(hào)跳轉(zhuǎn)小程序的實(shí)現(xiàn)代碼

    使用vue編寫(xiě)h5公眾號(hào)跳轉(zhuǎn)小程序的實(shí)現(xiàn)代碼

    這篇文章主要介紹了使用vue編寫(xiě)h5公眾號(hào)跳轉(zhuǎn)小程序,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11

最新評(píng)論