使用Vite构建纯js项目

背景

早先搭建了一个简易的网站,只实现了需要的js逻辑,并使用Terser把js代码进行打包,实现了一个静态网站功能。在后续需求中需要根据环境进行区分,不同环境请求不同的后端接口,干脆把打包构建逻辑修改为Vite去实现。

实现步骤

Vite官网:cn.vite.dev/guide/

  1. 当前目录结构如下:
  2. 使用以下命令下载Vite依赖包:npm install -D vite
  3. 添加vite.config.js文件,并添加相应配置
javascript 复制代码
import { defineConfig } from 'vite';
import { resolve } from 'path';

export default defineConfig(({ mode }) => {
  return {
    root: 'src',  // 逻辑代码都统一放在src目录下
    envDir: '..', // 因为root设置根目录为src,env文件在项目根目录下,所以需要向上找才能取到env环境文件
    base: '/', // 静态资源访问的路径,默认为/
    esbuild: {
      drop: mode === 'production' ? ['console', 'debugger'] : [],  // 默认使用esbuild打包,生产环境下打包去除console、debugger标记
    },
    build: {
      outDir: '../dist', // 打包后的目录设置,因为root设置根目录为src,需要往上一级目录找
      emptyOutDir: true, // 每次打包都清空dist目录
      rollupOptions: {
        input: resolve(__dirname, 'src/index.html'), // 入口文件设置
      },
    },
  };
});
  1. 以上配置导致需要往上一级找目录,因此以项目根目录为文件根目录,其实vite默认就是项目根目录,最终配置如下:
javascript 复制代码
import { defineConfig } from 'vite';
import { resolve } from 'path';

export default defineConfig(({ mode }) => {
  return {
    esbuild: {
      drop: mode === 'production' ? ['console', 'debugger'] : [],
    },
    build: {
      outDir: './dist',
      emptyOutDir: true,
      rollupOptions: {
        input: resolve(__dirname, 'src/index.html'),
      },
    },
  };
});
  1. f

遇到的问题

  1. 已经添加环境变量文件.env.dev,但是在运行命令时,没法取到环境变量文件内的内容,运行命令如下: "build:dev": "vite build --mode development" Vite默认支持.env.development环境变量文件,不支持dev后缀的环境变量文件,需改成development
  2. 有两个js文件,script1.js、script2.js,在script1.js中引入script2.js的全局变量window.fun,引入方式为在index.html中引入,此时在script1.js中无法引入script2.js的全局变量window.fun
xml 复制代码
<script type="module" src="./script1.js"></script>
<script type="module" src="./script2.js"></script>

原因:在Vite打包时把script1和script2分模块打包,各个模块中的变量都是局部变量,无法互通。 解决方案1:去掉分模块打包

xml 复制代码
<script src="./script1.js"></script>
<script type="module" src="./script2.js"></script>

解决方案2:使用ESmodule方法,export导出script2的fun变量,使用import导入到script1内

kotlin 复制代码
// script1.js
import fun from 'script2.js'
kotlin 复制代码
// script2.js
const fun=**
export default fun;
相关推荐
GIS之路8 小时前
GDAL 实现矢量裁剪
前端·python·信息可视化
是一个Bug8 小时前
后端开发者视角的前端开发面试题清单(50道)
前端
Amumu121388 小时前
React面向组件编程
开发语言·前端·javascript
持续升级打怪中8 小时前
Vue3 中虚拟滚动与分页加载的实现原理与实践
前端·性能优化
GIS之路9 小时前
GDAL 实现矢量合并
前端
hxjhnct9 小时前
React useContext的缺陷
前端·react.js·前端框架
前端 贾公子9 小时前
从入门到实践:前端 Monorepo 工程化实战(4)
前端
菩提小狗9 小时前
Sqlmap双击运行脚本,双击直接打开。
前端·笔记·安全·web安全
前端工作日常9 小时前
我学习到的AG-UI的概念
前端
韩师傅9 小时前
前端开发消亡史:AI也无法掩盖没有设计创造力的真相
前端·人工智能·后端