vue页面批量引入组件的操作代码
更新时间:2022年12月12日 14:50:10 作者:陌上烟雨寒
这篇文章主要介绍了vue页面批量引入组件,本文结合示例代码给大家讲解的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
<template> <div> <template v-for="(item) in names"> <component :is="item" :key="item" /> </template> </div> </template> <script> // 可行了 import path from 'path' // require.context(param1,param2,param3) param1:路径; param2: 是否搜索子文件夹; param3: 文件类型,可正则 const files = require.context('@/components/Menu/Dialog', true, /\.vue$/) const dialogs = {} const names = [] // 组件导入 files.keys().forEach((key) => { /** * * 获取vue文件名 * 法一:用正则表达式匹配 * key.replace(/^\.\/(.*)\.\w+$/, '$1') * 法一:path.basename获取vue文件名 * import path from 'path' * path.basename(path[, ext]) * path.basename() 方法会返回 path 的最后一部分。 尾部的目录分隔符会被忽略。 **/ // 获取文件名 法一 // var name = fileName // .split('/') // .pop() // .replace(/\.\w+$/, ''); // 获取文件名 法二 const name = path.basename(key, '.vue') names.push(name) dialogs[name] = files(key).default || files(key) }) export default { name: 'Dialogs', components: dialogs, data() { return { names: names } } } </script> <style lang="scss" scoped />
知识点:
require.context(param1,param2,param3)
- param1:路径;
- param2: 是否搜索子文件夹;
- param3: 文件类型,可正则
path.basename(path[, ext])
方法会返回 path 的最后一部分。 尾部的目录分隔符会被忽略
- path :string
- ext :string 可选的文件扩展名。
path.basename('/目录1/目录2/文件.html'); // 文件.html
path.basename('/目录1/目录2/文件.html', '.html'); // 文件
到此这篇关于vue页面批量引入组件的文章就介绍到这了,更多相关vue页面批量引入组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue keepAlive实现不同的路由共用一个组件component的缓存问题(推荐)
这篇文章主要介绍了Vue keepAlive实现不同的路由共用一个组件component的缓存问题,实现方式使用Vue keepAlive实现页面缓存,需要的朋友可以参考下2022-08-08vue 插值 v-once,v-text, v-html详解
这篇文章主要介绍了vue 插值 v-once,v-text, v-html详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-01-01vue.js默认路由不加载linkActiveClass问题的解决方法
这篇文章主要给大家介绍了关于vue.js默认路由不加载linkActiveClass问题的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧。2017-12-12
最新评论