vite+vue3+ts中使用require.context | 报错require is not defined | 获取文件夹中的文件名

vite+vue3+ts中使用require.context|报错require is not defined|获取文件夹中的文件名

目录

一、问题背景

如题在vite+vue3+ts中使用required.context时报错如下:

代码:需求为获取文件夹中的后缀为.vue的文件相对路径

js 复制代码
const files = require.context('@/views', true, /\.vue$/)
const result = []
files.keys().forEach((key) => {
    result.push({
        label: key.replace(/(\.\/|\.vue)/g, ''),
        value: key.replace(/(\.\/|\.vue)/g, '')
    })
})

报错如下

按照网上搜到的解决方案在代码中加入两行代码(如下)后,产生新的报错如下:

js 复制代码
import { createRequire } from 'module';
const require = createRequire(import.meta.url);

二、报错原因

require.context()webpack用来查找文件内容的,在vite中不适用。webpack官网对require.context的详解如下:

网址 : requirecontext

三、解决方法

vite中可以使用import.meta.glob()方法实现导入资源,注意import.meta.globEager()已弃用。

官网详解

网址import.meta.glob

修改后可用的代码如下

js 复制代码
// 获取src/pages下的vue文件地址
searchFiles () {
    const files = import.meta.glob( '@/pages/**/*.vue', { eager: true })
    console.log('files',files);
    const result = []
    Object.keys(files).forEach(fileName=>{
        // console.log('fileName',fileName);
        result.push({
            label: fileName.replace(/(\.\/|\.vue)/g, ''),
            value: fileName.replace(/(\.\/|\.vue)/g, '')
        })
    })
    this.vue_files = result
    console.log('vue files',this.vue_files);
}

打印出的files格式如下:如果想获得文件的相对路径,则用Object.keys()获取到files对象的key值即可

注:/**的意思是匹配所有文件夹及里面的子文件夹,相当于reqiure.context中第二个参数useSubdirectories = true的作用。

复制代码
/**的意思是所有文件夹及里面的子文件夹
/*是所有文件夹,不含子文件夹
相关推荐
叫我少年几秒前
Vue 3 集成 Vue Router:从基础配置到项目实践
前端·路由
Highcharts.js1 分钟前
Highcharts React 5.0 正式版:支持 ES 模块化、组件更精简、开发体验全面升级
前端·javascript·react.js·elasticsearch·前端框架·highcharts
大江东去浪淘尽千古风流人物6 分钟前
【X-Restormer++】全天候图像恢复赛冠军方案:三项创新解析及对VIO/SLAM前端的工程价值
前端
LaughingZhu8 分钟前
Claude Code 时代的写作:为什么 HTML 正在取代 Markdown
前端·人工智能·html
Shadow(⊙o⊙)17 分钟前
qt中自定义槽函数 内部继承逻辑、GUI+CLI协同1.0
开发语言·前端·c++·qt
hexu_blog18 分钟前
前端VUE后端java实现智能抠图
前端·javascript·vue.js·java处理抠图·vue实现智能抠图
__log25 分钟前
AI前端工程化实战指南:10大核心场景的“解题思路“与“避坑指南“
前端·人工智能
ljt272496066126 分钟前
Vue笔记(一)--模板
前端·vue.js·笔记
广州华水科技26 分钟前
单北斗GNSS变形监测一体机在水库安全监测中的应用与优势
前端
光影少年28 分钟前
react的useRef 作用:获取DOM、保存可变数据、区别 createRef
前端·javascript·react.js