在webpack中通过 unplugin-vue-define-options 插件, 实现 在Vue3 setup语法糖中,自定义组件的 name 属性,最后实现组件的全局自动注册,

①、安装插件 npm install unplugin-vue-define-options -D

②、在vue.config.js中配置插件

//vue.config.js 
configureWebpack: {
    plugins: [
      require('unplugin-vue-define-options/webpack')()
    ]
  }

③、需要ts类型的可在tsconfig中进行如下配置(未使用ts的忽略此步骤)

// tsconfig.json
{
  "compilerOptions": {
    // ...
    "types": ["unplugin-vue-define-options" /* ... */]
  }
}

④、直接在组件中使用

<template lang="">
  <div>
    test
  </div>
</template>
<script lang="ts" setup>
defineOptions({
  name: 'AppPagination'
})
</script>
<style lang="">

</style>

⑤、在组件出口中进行组件自动全局注册

import { App } from 'vue'

const importFn = require.context('./', false, /\.vue$/)

export default {
  install (app:App) {
    // 根据keys批量注册
    importFn.keys().forEach(path => {
      // 导入组件
      const component = importFn(path).default

      // 进行注册
      app.component(component.name, component)
    })
  }
}

注意:此方法用起来不方便,如果仅仅想实现自动注册的话可以用下面的方法

在获取组件name上做了改进,以前是获取组件的name, 现在是获取该组件的名称,

import { App } from 'vue'
const ret = require.context('../', false, /\.vue$/)

export default {
  install (app: App) {
    // 根据keys批量注册
    ret.keys().forEach(path => {
      // 导入组件
      const component = ret(path).default
      // 获取组件名称
      const name = path.split('.')[1].slice(1)
      app.component(name, component)
    })
  }
}

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 9
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值