中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue3全局組件自動注冊功能如何實現

發布時間:2023-02-03 09:09:46 來源:億速云 閱讀:254 作者:iii 欄目:開發技術

這篇文章主要介紹了vue3全局組件自動注冊功能如何實現的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇vue3全局組件自動注冊功能如何實現文章都會有所收獲,下面我們一起來看看吧。

vue3全局組件自動注冊

第一步:建文件

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

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

vue3全局組件自動注冊功能如何實現

第二步:寫函數

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

vue3全局組件自動注冊功能如何實現

在Index.js中寫入以下工具函數:

// 全局組件注冊 需要到coms這個目錄下注冊
 
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);
        });
    }
};

注意:這里我沒有用 defaultObj.__file 來取文件路徑,是因為生產環境下__file屬性會被刪除,會導致如下報錯

vue3全局組件自動注冊功能如何實現

第三步:導入文件

在main.js中導入工具函數并掛載到app中

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

第四步:全局使用

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

vue3全局組件自動注冊功能如何實現

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

補充: Vue3注冊全局組件

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

1.注冊單個全局組件

在main.ts 引入我們的組件跟隨在createApp(App) 后面 切記不能放到mount 后面這是一個鏈式調用用

其次調用 component 第一個參數組件名稱 第二個參數組件實例

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)就是注冊全局組件 (‘自定義鍵名',組件名)

使用方法

直接在其他vue頁面 立即使用即可 無需引入

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

2.批量注冊全局組件

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

src/components中新建index.ts用來將所有需要全局注冊的組件導入

vue3全局組件自動注冊功能如何實現

?: 如果使用的是 JS 可以刪除類型校驗

import type { Component } from 'vue' //import type 是用來協助進行類型檢查和聲明的,在運行時是完全不存在的。

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

// ?如果使用的是 JS 可以刪除類型校驗

const components: {

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

} = {

  SvgIcon

}

export default components

2. 在main.ts中導入

?這里使用循環的方式, 將每個全局組件進行注冊

import { createApp } from 'vue'

import ElementPlus from 'element-plus'

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

import App from './App.vue'

import router from './router'

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

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

const app = createApp(App)

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

// 注冊全局的組件 (對所有需要注冊的組件進行遍歷并注冊)

for (const componentItme in globalComponent) {

  app.component(componentItme, globalComponent[componentItme])

}

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

3. 如果使用TS編寫,還需要在和main.ts同級的目錄, 創建一個components.d.ts, 用來處理組件引入報錯的問題和添加組件類型提示

vue3全局組件自動注冊功能如何實現

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

//要擴充@vue/runtime-core包的聲明

declare module '@vue/runtime-core' {

  export interface GlobalComponents { //這里擴充"ComponentCustomProperties"接口

    SvgIcon: typeof SvgIcon

  }

}

4. 最后直接導入即可

vue3全局組件自動注冊功能如何實現

關于“vue3全局組件自動注冊功能如何實現”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“vue3全局組件自動注冊功能如何實現”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

内丘县| 鹤庆县| 富阳市| 河源市| 赞皇县| 上饶县| 黎川县| 新沂市| 安阳市| 应城市| 吉隆县| 保康县| 韶山市| 江津市| 烟台市| 宝坻区| 西乡县| 奉新县| 内丘县| 宜章县| 陕西省| 百色市| 南昌县| 时尚| 漯河市| 七台河市| 蒙山县| 和田市| 喀喇沁旗| 昌邑市| 福海县| 建昌县| 奉化市| 尚志市| 乌拉特中旗| 黔江区| 衡山县| 安丘市| 新泰市| 外汇| 大方县|