Vue 批量注册全局组件

这篇具有很好参考价值的文章主要介绍了Vue 批量注册全局组件。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

为什么要批量注册全局组件?

在项目开发中,我们经常会封装一些全局组件,然后在入口文件中统一导入,这时就会出现一个问题,如果我封装了很多组件,假如有成百上千的组件,都想注册成全局组件,那岂不是入口文件要引入几千行,显然这样是很笨拙的,所以就出现了批量注册全局组件。

注:批量注册全局组件的方法有很多,这里我只列举我使用的方法

铺垫:在讲解如何批量注册全局组件之前,需要先铺垫两个 js 的方法

(一)Object.keys()

1、语法

Object.keys(obj)

2、参数

obj  一个对象

3、返回值

返回一个由给定对象自身可枚举的字符串键属性键组成的数组

4、示例

// 简单数组
const arr = ["a", "b", "c"];
console.log(Object.keys(arr)); // ['0', '1', '2']

// 类数组对象
const obj = { 0: "a", 1: "b", 2: "c" };
console.log(Object.keys(obj)); // ['0', '1', '2']

// 键的顺序随机的类数组对象
const anObj = { 100: "a", 2: "b", 7: "c" };
console.log(Object.keys(anObj)); // ['2', '7', '100']

// getFoo 是一个不可枚举的属性
const myObj = Object.create(
  {},
  {
    getFoo: {
      value() {
        return this.foo;
      },
    },
  },
);
myObj.foo = 1;
console.log(Object.keys(myObj)); // ['foo']

(二)Object.entries()

1、语法

Object.entries(obj)

2、参数

obj  一个对象

3、返回值

返回一个由给定对象自有的可枚举字符串键属性的键值对组成的数组。每个键值对都是一个包含两个元素的数组:第一个元素是属性的键(始终是字符串),第二个元素是属性值。

4、示例

const obj = { foo: "bar", baz: 42 };
console.log(Object.entries(obj)); // [ ['foo', 'bar'], ['baz', 42] ]

// 类数组对象
const obj = { 0: "a", 1: "b", 2: "c" };
console.log(Object.entries(obj)); // [ ['0', 'a'], ['1', 'b'], ['2', 'c'] ]

// 具有随机键排序的类数组对象
const anObj = { 100: "a", 2: "b", 7: "c" };
console.log(Object.entries(anObj)); // [ ['2', 'b'], ['7', 'c'], ['100', 'a'] ]

// getFoo 是一个不可枚举的属性
const myObj = Object.create(
  {},
  {
    getFoo: {
      value() {
        return this.foo;
      },
    },
  },
);
myObj.foo = "bar";
console.log(Object.entries(myObj)); // [ ['foo', 'bar'] ]

(三)如何批量注册全局组件

前面已经讲解了具体方法的使用,下面直接上批量注册全局组件的代码

// 引入项目中所有想注册成全局组件的组件
// 引入全局 Svg 图标组件
import SvgIcon from './SvgIcon/index.vue'
// 引入全局 Pagination 分页器组件
import Pagination from './Pagination/index.vue'
// 引入 element-plus 全部图标组件
import * as ElementPlusIconsVue from '@element-plus/icons-vue'
// 定义一个全局对象,将所有的组件都放到这个对象里面
const allGlobalComponent:any = {SvgIcon,Pagination}
// 对外暴露一个插件对象,动态注册全局组件
export default{
    // 这里一定要叫作 install 方法
    install(app:any){
        // 通过 Object.keys 遍历全局对象的每一个 key
        Object.keys(allGlobalComponent).forEach(key => {
            // 将全局对象里面的组件都注册成全局组件
            app.component(key,allGlobalComponent[key])
        })
        // 将 element-plus 提供的图标注册为全局组件
        for(const [key,component] of Object.entries(ElementPlusIconsVue)){
            // 将 element-plus 的所有图标组件注册成全局组件
            app.component(key,component)
        }
    }
}

上面就是我自己使用批量注册全局组件的方法,当然批量注册全局组件的方法有很多,感兴趣的可以再去研究。

既然看到这了,还请各位看官大人给点个赞!文章来源地址https://www.toymoban.com/news/detail-815046.html

到了这里,关于Vue 批量注册全局组件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • elementPlus——图标引入+批量注册全局组件——基础积累

    因为我们要根据路由配置对应的图标,也要为了后续方便更改。因此我们将所有的图标注册为全局组件。(使用之前将分页器以及矢量图注册全局组件的自定义插件)(所有图标全局注册的方法element-plus文档中已给出) 经过上面的步骤,就可以把 elementPlus 自带的 icon 图标全

    2024年02月12日
    浏览(29)
  • 记录--封装一个通过js调用的全局vue组件

    在使用vue项目编写的时候,不可避免的会碰到需要时js api来调用组件进行显示的情况 例如饿了么element ui 的 Notification 通知、Message 消息提示等组件 虽然已经提供了,但是由于api的限制,我们只能通过特定的参数来有限的改变组件的样式 之前的文章说过可以使用 new Vue() 、

    2024年02月09日
    浏览(56)
  • 整体认识和路由配置、基础数据渲染、热榜区域实现、图片预览组件封装、认识SKU组件、通用组件统一注册全局(详情页)【Vue3】

    整体业务认识 路由配置 准备组件模板 配置路由 绑定模板测试跳转 封装接口 获取数据渲染模版 思考:渲染模版时遇到对象的多层属性访问可能出现什么问题? 模块实现整体分析 结论:两块热榜相比, 结构一致,标题title和列表内容不同 渲染基础热榜数据 1- 准备模版 2- 封

    2024年02月15日
    浏览(47)
  • uni-app:vue3 + uni-app 在微信小程序中无法使用app.component全局注册组件

    按上文中的代码执行后,会发现在微信小程序开发中全局注册的组件是无法显示的,这是uniapp的一个未解决bug, 在uniapp中出了可以通过vue实例的component方法注册全局组件外,uniapp支持另一种全局注册的方式,就是通过 easycom 扫描注册,步骤如下 easycom 的扫描流程是:通过代码

    2024年02月16日
    浏览(91)
  • vue~全局插件和全局方法的注册

    本文介绍如何在vue中定义插件,注册插件和使用插件 /src/plugins /src/plugins/index.js /src/main.js 注意在其它js中还是需要手动引用插件的,这个main.js中的注册,只有vue文件有效. 还是在上面的/src/main.js中进行添加prototype的定义 从插件中引入一个方法addDateRange import { addDateRange } from

    2024年02月08日
    浏览(27)
  • Vue中的全局组件与局部组件

    聚沙成塔·每天进步一点点 Vue学习之旅的奇妙世界 欢迎大家来到 Vue 技能树参考资料专栏!创建这个专栏的初衷是为了帮助大家更好地应对 Vue.js 技能树的学习。每篇文章都致力于提供清晰、深入的参考资料,让你能够更轻松、更自信地理解和掌握 Vue.js 的核心概念和技术。订

    2024年01月17日
    浏览(44)
  • VUE工程化--vue组件注册

    组件注册的两种方式: 1. 局部注册:只能在注册的组件内使用 2. 全局注册:所有组件内都能使用   局部注册步骤:         1、导入         2、注册组件--注册成html标签(components中)         3、页面中使用标签 实现效果:   全局注册步骤( main.js ):         1、导入

    2024年01月18日
    浏览(37)
  • vue3深入组件: 组件注册

    一个 Vue 组件在使用前需要先被“注册”,这样 Vue 才能在渲染模板时找到其对应的实现。组件注册有两种方式:全局注册和局部注册。 全局注册 我们可以使用 Vue 应用实例的 .component() 方法,让组件在当前 Vue 应用中全局可用。 全局注册的问题: 全局注册,但并没有被使用

    2024年01月18日
    浏览(40)
  • Vue定义全局组件的三种方式

    第一种方式 1.1使用 Vue.extend 来创建全局的Vue组件 1.2使用 Vue.component(‘组件的名称’, 创建出来的组件模板对象) Vue.component 第一个参数:组件的名称,引用组件的时候,就是一个HTML 标签形式来引入的 第二个参数: Vue.extend 创建的组件 ,其中 template 就是组件将来要展示的HTML内容 1

    2024年02月07日
    浏览(49)
  • Vue 注册组件介绍

    Vue组件是一种可复用的Vue实例,用于封装可重用的HTML元素、JavaScript代码和CSS样式。它可以让开发者更好地组织和复用代码,使Web应用程序更加可维护和可扩展 Vue组件通常由三部分组成:模板(template)、数据(data)和方法(methods)。 模板:用于定义组件的 结构和布局 ;

    2024年02月04日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包