使用uni-app自动注册全局组件

全局共用组件为经常使用,所以自动化注册是个不错的选择;

方式1webpack的 require.context方式
此方式适用于浏览器端,如需兼容看下面的方式2

在这里插入图片描述

// /*
//  **全局注册组件
//  ** 放在components/global文件夹下
//  ** 仅适用于h5端, 微信端-移步到pages.json的easycom配置, 以App开头命名name
//  */
const requireComponent = require.context(
	'./global',
	true,
	/\.vue$/
)
export
default Vue => {
	requireComponent.keys().forEach(fileName => {
		const componentConfig = requireComponent(fileName),
			component = componentConfig?.default
		// Vue.component(component.name, component) //同步
		// Vue.component(component.name, () =>  import(`${componentConfig.__file}`))  //异步 -会报警告,webpack版本问题 改成Promise.resolve
		Vue.component(component.name, () =>  Promise.resolve(require(`${componentConfig.__file}`)))  //异步
	})
}

方式2easycom方式

打开pages.json 文件,加入easycom配置:
在这里插入图片描述

	"easycom": {
		"autoscan": true, 
		"custom": { 
			"^App(.*)": "@/components/global/App$1.vue",
			"^u-(.*)": "uview-ui/components/u-$1/u-$1.vue"
		}
	},
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值