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

Vue實(shí)現(xiàn)批量注冊全局組件的示例代碼

 更新時(shí)間:2024年01月22日 10:58:41   作者:M_emory_  
在項(xiàng)目開發(fā)中,我們經(jīng)常會封裝一些全局組件,然后在入口文件中統(tǒng)一導(dǎo)入,所以本文主要為大家詳細(xì)介紹了Vue如何批量注冊全局組件,感興趣的小伙伴可以了解下

為什么要批量注冊全局組件

在項(xiàng)目開發(fā)中,我們經(jīng)常會封裝一些全局組件,然后在入口文件中統(tǒng)一導(dǎo)入,這時(shí)就會出現(xiàn)一個(gè)問題,如果我封裝了很多組件,假如有成百上千的組件,都想注冊成全局組件,那豈不是入口文件要引入幾千行,顯然這樣是很笨拙的,所以就出現(xiàn)了批量注冊全局組件。

注:批量注冊全局組件的方法有很多,這里我只列舉我使用的方法

鋪墊:在講解如何批量注冊全局組件之前,需要先鋪墊兩個(gè) js 的方法

1.Object.keys()

1、語法

Object.keys(obj)

2、參數(shù)

obj  一個(gè)對象

3、返回值

返回一個(gè)由給定對象自身可枚舉的字符串鍵屬性鍵組成的數(shù)組

4、示例

// 簡單數(shù)組
const arr = ["a", "b", "c"];
console.log(Object.keys(arr)); // ['0', '1', '2']
 
// 類數(shù)組對象
const obj = { 0: "a", 1: "b", 2: "c" };
console.log(Object.keys(obj)); // ['0', '1', '2']
 
// 鍵的順序隨機(jī)的類數(shù)組對象
const anObj = { 100: "a", 2: "b", 7: "c" };
console.log(Object.keys(anObj)); // ['2', '7', '100']
 
// getFoo 是一個(gè)不可枚舉的屬性
const myObj = Object.create(
  {},
  {
    getFoo: {
      value() {
        return this.foo;
      },
    },
  },
);
myObj.foo = 1;
console.log(Object.keys(myObj)); // ['foo']

2.Object.entries()

1、語法

Object.entries(obj)

2、參數(shù)

obj  一個(gè)對象

3、返回值

返回一個(gè)由給定對象自有的可枚舉字符串鍵屬性的鍵值對組成的數(shù)組。每個(gè)鍵值對都是一個(gè)包含兩個(gè)元素的數(shù)組:第一個(gè)元素是屬性的鍵(始終是字符串),第二個(gè)元素是屬性值。

4、示例

const obj = { foo: "bar", baz: 42 };
console.log(Object.entries(obj)); // [ ['foo', 'bar'], ['baz', 42] ]
 
// 類數(shù)組對象
const obj = { 0: "a", 1: "b", 2: "c" };
console.log(Object.entries(obj)); // [ ['0', 'a'], ['1', 'b'], ['2', 'c'] ]
 
// 具有隨機(jī)鍵排序的類數(shù)組對象
const anObj = { 100: "a", 2: "b", 7: "c" };
console.log(Object.entries(anObj)); // [ ['2', 'b'], ['7', 'c'], ['100', 'a'] ]
 
// getFoo 是一個(gè)不可枚舉的屬性
const myObj = Object.create(
  {},
  {
    getFoo: {
      value() {
        return this.foo;
      },
    },
  },
);
myObj.foo = "bar";
console.log(Object.entries(myObj)); // [ ['foo', 'bar'] ]

3.如何批量注冊全局組件

前面已經(jīng)講解了具體方法的使用,下面直接上批量注冊全局組件的代碼

// 引入項(xiàng)目中所有想注冊成全局組件的組件
// 引入全局 Svg 圖標(biāo)組件
import SvgIcon from './SvgIcon/index.vue'
// 引入全局 Pagination 分頁器組件
import Pagination from './Pagination/index.vue'
// 引入 element-plus 全部圖標(biāo)組件
import * as ElementPlusIconsVue from '@element-plus/icons-vue'
// 定義一個(gè)全局對象,將所有的組件都放到這個(gè)對象里面
const allGlobalComponent:any = {SvgIcon,Pagination}
// 對外暴露一個(gè)插件對象,動態(tài)注冊全局組件
export default{
    // 這里一定要叫作 install 方法
    install(app:any){
        // 通過 Object.keys 遍歷全局對象的每一個(gè) key
        Object.keys(allGlobalComponent).forEach(key => {
            // 將全局對象里面的組件都注冊成全局組件
            app.component(key,allGlobalComponent[key])
        })
        // 將 element-plus 提供的圖標(biāo)注冊為全局組件
        for(const [key,component] of Object.entries(ElementPlusIconsVue)){
            // 將 element-plus 的所有圖標(biāo)組件注冊成全局組件
            app.component(key,component)
        }
    }
}

上面就是我自己使用批量注冊全局組件的方法,當(dāng)然批量注冊全局組件的方法有很多,感興趣的可以再去研究。

到此這篇關(guān)于Vue實(shí)現(xiàn)批量注冊全局組件的示例代碼的文章就介紹到這了,更多相關(guān)Vue注冊全局組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue 封裝防刷新考試倒計(jì)時(shí)組件的實(shí)現(xiàn)

    Vue 封裝防刷新考試倒計(jì)時(shí)組件的實(shí)現(xiàn)

    這篇文章主要介紹了Vue 封裝防刷新考試倒計(jì)時(shí)組件的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • 源碼分析Vue.js的監(jiān)聽實(shí)現(xiàn)教程

    源碼分析Vue.js的監(jiān)聽實(shí)現(xiàn)教程

    這篇文章主要通過源碼分析介紹了Vue.js的監(jiān)聽實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),相信對大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。
    2017-04-04
  • vue .then和鏈?zhǔn)秸{(diào)用操作方法

    vue .then和鏈?zhǔn)秸{(diào)用操作方法

    這篇文章主要介紹了vue .then和鏈?zhǔn)秸{(diào)用操作方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07
  • Vue父組件向子組件傳值以及data和props的區(qū)別詳解

    Vue父組件向子組件傳值以及data和props的區(qū)別詳解

    這篇文章主要介紹了Vue父組件向子組件傳值以及data和props的區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • Vue.js directive自定義指令詳解

    Vue.js directive自定義指令詳解

    這篇文章主要介紹了Vue.js directive自定義指令詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • Vue組件之間四種通信方式詳解

    Vue組件之間四種通信方式詳解

    vue框架提供了前端開發(fā)組件的思想,可以通過組件來組合成一個(gè)完整的頁面,都是隨著組件數(shù)量原來越多,組件之間難免需要相互通信。本文將為大家介紹四種組件間的通信方式,需要的可以參考一下
    2022-01-01
  • Vue后臺管理系統(tǒng)權(quán)限控制與動態(tài)路由的實(shí)現(xiàn)

    Vue后臺管理系統(tǒng)權(quán)限控制與動態(tài)路由的實(shí)現(xiàn)

    本文主要介紹了Vue后臺管理系統(tǒng)權(quán)限控制與動態(tài)路由的實(shí)現(xiàn),可以根據(jù)用戶的角色靈活控制頁面訪問權(quán)限,提高系統(tǒng)的安全性和用戶體驗(yàn),感興趣的可以了解一下
    2025-04-04
  • 詳解Vue自定義指令如何實(shí)現(xiàn)處理圖片加載失敗的碎圖

    詳解Vue自定義指令如何實(shí)現(xiàn)處理圖片加載失敗的碎圖

    這篇文章主要介紹了詳解Vue自定義指令如何實(shí)現(xiàn)處理圖片加載失敗的碎圖,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-02-02
  • 使用Webpack提升Vue.js應(yīng)用程序的4種方法(翻譯)

    使用Webpack提升Vue.js應(yīng)用程序的4種方法(翻譯)

    這篇文章主要介紹了使用Webpack提升Vue.js應(yīng)用程序的4種方法(翻譯),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • 基于vue的換膚功能的示例代碼

    基于vue的換膚功能的示例代碼

    本篇文章主要介紹了基于vue的換膚功能的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10

最新評論