当前位置 : 主页 > 网络编程 > JavaScript >

关于Vite不能使用require问题的解决方法

来源:互联网 收集:自由互联 发布时间:2023-02-01
咱们在vue2中是不存在require is not defined问题的,那是因为webpack帮我们解决了,开发时在内部对其了转换 为什么非要使用require语法?因为require语法有时候确实蛮好用的啊,咱们在vue2中可

咱们在vue2中是不存在require is not defined问题的,那是因为webpack帮我们解决了,开发时在内部对其了转换

为什么非要使用require语法?因为require语法有时候确实蛮好用的啊,咱们在vue2中可以通过require语法,定义变量,动态获取一些静态资源

vite却不能使用,确实有点点的难受,最近刚发现了一种开发时依赖插件vite-plugin-require-transform,那就试一下吧

vitejs/ awesome-vite - github地址: https://github.com/vitejs/awesome-vite

进去之后咱们搜索 require,然后选择第三个

带你进去之后即 vit-plugin-require-transform

然后安装 

yarn add -D vite-plugin-require-transform
or
npm i vite-plugin-require-transform --save-dev

然后vite.config.js中配置 

import { defineConfig } from 'vite'
import requireTransform from 'vite-plugin-require-transform';
 
export default defineConfig({
  plugins: [
    requireTransform({
      fileRegex: /.js$|.vue$/
    }),
  ],
});

这样就可以了 

然后就去抓紧抓紧试一下 

第一: 

<img class="img" :src="require('@/assets/login/login-bg.jpg')" alt="">

这样是可以的,也不会报错了,正常使用require 

第二: 

<img class="img" :src="require(`@/assets/login/login-bg.jpg`)" alt="">

这种就不行!报错,和第一种的区别就是把普通字符串改成了模板字符串(``)反引号,这种是不行的,有点坑 

第三: 

<template>
  <div class="img">
    <img class="img" :src="img1" alt="">
  </div>
</template>
<script setup>
const img1 = require('@/assets/login/login-bg.jpg')
</script>

这种也不行 !报错!

又是一个坑 

第四: 

<template>
  <div class="img">
    <img class="img" :src="img2" alt="">
  </div>
</template>
<script setup>
const img1 = require('@/assets/login/login-bg.jpg')
let img2 = img1
</script>
<style scoped>
.img {
  width: 100%;
  height: 100%;
}
</style>

这样竟然可以!完全不报错! 

第五(使用变量): 

<template>
  <div class="img">
    <img class="img" :src="img2" alt="">
  </div>
</template>
<script setup>
let a = 'login'
const img1 = require('@/assets/' + a +'/login-bg.jpg')
let img2 = img1
</script>
<style scoped>
.img {
  width: 100%;
  height: 100%;
}
</style>

刚才使用``模板字符串的都不行,变量更不用写了,这次换个写法,同样也是不行

唉,有点失望,,,,真不知道出这个插件的意义在哪,这也不实用啊,跟webpack那个require差的有点儿远啊,这个插件就是将代码从 require 语法转换为 import ,但是我发现还不如import好用的,倒不如直接使用import了,都知道存在即合理,哈哈哈哈,就仅仅只为了解决require is not defined而出现吗

还是我太菜了吗。。。但是使用vue-cli3 + vue2的时候确实不存在上面的问题

总结

到此这篇关于Vite不能使用require问题的文章就介绍到这了,更多相关Vite不能使用require内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!

上一篇:关于页面加载即执行JQuery的三种方法小结
下一篇:没有了
网友评论