标签:vue const name 批量 default comName requireComponent 组件
方式一,在页面引入的方式 function camelCase(s) { return s.replace(/-\w/g,function(x){ return x.slice(1).toUpperCase() }) }const allComponents = require.context( '../components', true, /\.vue$/ )
let resComponents = {}
allComponents.keys().forEach(comName=>{ let name = camelCase(comName) const comp = allComponents(comName) resComponents[name.replace(/^\.\/(.*)\.\w+$/,"$1")] = comp.default })
export default resComponents 方式二:全局方式 const requireComponent = require.context( // 其组件目录的相对路径 './components', // 是否查询其子目录 true, // 匹配基础组件文件名的正则表达式 /\.vue$/ )
// console.log('实时',requireComponent);
requireComponent.keys().forEach(fileName => { // console.log('fie',fileName); // 获取组件配置 const componentConfig = requireComponent(fileName) // 全局注册组件 Vue.component( componentConfig.default.name, // 此处的name,是组件属性定义的name // 如果这个组件选项是通过 `export default` 导出的, // 那么就会优先使用 `.default`, // 否则回退到使用模块的根。 componentConfig.default ) })
标签:vue,const,name,批量,default,comName,requireComponent,组件 来源: https://www.cnblogs.com/fanqieyuanzi/p/16363712.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。