当前位置:   article > 正文

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

require is not defined

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

一、问题背景

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

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

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, '')
    })
})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

报错如下

image-20231009122817001

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

import { createRequire } from 'module';
const require = createRequire(import.meta.url);
  • 1
  • 2

image-20231009123739081

二、报错原因

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

网址: requirecontext

image-20231009123417973

三、解决方法

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

官网详解

网址import.meta.glob

image-20231009125016115

修改后可用的代码如下

// 获取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);
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

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

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

/**的意思是所有文件夹及里面的子文件夹
/*是所有文件夹,不含子文件夹
  • 1
  • 2
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/86270
推荐阅读
相关标签
  

闽ICP备14008679号