Vue3+vite中使用import.meta.glob

前言:

        在vue2中支持require导入模块或文件但是在vue3中已经不支持require导入了,为此vite提供了一个全新的方法import.meta.glob方法来支持批量导入文件 

import.meta.glob

匹配到的文件默认是懒加载的,通过动态导入实现,并会在构建时分离为独立的 chunk。如果你倾向于直接引入所有的模块(例如依赖于这些模块中的副作用首先被应用),你可以传入 { eager: true } 作为第二个参数:

const modules = import.meta.glob('./dir/*.js', { eager: true })

使用篇:

区分*和**分别代表什么 "*"是代表所有文件 "**"是代表所有文件夹 你可以理解为枚举 这个是固定的

"*" 指的就是文件那么文件后面肯定可以添加后缀  所有这三个点我们需要先搞明白

//用法一

  import.meta.glob("../src/*"); // '*'表示文件 获取src下面所有非文件夹类型文件【重点 仅获取一级目录不是所有目录】

我知道现在对这个所说的一级目录可能有点头晕 没关系接下来看用法三你就明白了

  //用法二

  import.meta.glob("../src/*.js"); // '*'表示文件 获取src下面所有以.js结尾的文件【重点 仅获取一级目录不是所有目录】

我们已经知道 "*"是代表所有文件 "**"是代表所有文件夹 它们是指目录下的所有而并不是单个文件或文件夹 当我们指定某一个目录那么他就是获取指定目录下的所有文件 

  //用法三

  import.meta.glob("../src/**/*"); // '*'表示文件 获取src下面所有以.js结尾的文件【重点 所有目录下的文件】

 //用法四

  import.meta.glob(["../src/assets/*", "../src/components/*"]); // 数组写法同时获取指定文件夹下面的所有文件

//用法五

  import.meta.glob(["../src/components/**/*","!../src/components/**/index.vue"]) // '!'开头可以忽略结果中的一些文件 获取components文件夹下面所有目录下的文件 排除所有文件夹目录下index.vue的文件

创作不易 你的三连是我更新的动力

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值