前言
我们开发中不可避免的要根据环境变量来做一些逻辑分支,在vite中有两种实现方式,即define和.env文件
示例
通过cross-env包设置环境变量,并通过define向页面中export
在.env中使用VITE_作为开头命名
源码
define
读取配置的整体流程和proxy差不多,这里就不展开说了,总之就是,能拿到vite.config.js中的配置
开发环境
对于开发环境vite并不会进行编译,而是将其挂载到全局,我们知道,定义在后的script标签是能够访问上一个script中定义的变量的,就像下边这样
为了避免变量名称冲突导致报错,故挂载到window最合适
那么,需要单独创建script标签吗?可以,但不必要!因为vite已经向浏览器塞了个client.js了,直接利用其作为载体即可,这里将define中定义的配置项转换成字符串,并对原代码中的占位标识(__DEFINES__)作替换
最后,当浏览器加载到client.js时,直接将__DEFINES__的值挂载到window即可
非开发环境
非开发环境会使用plugin对源码中使用到的变量做替换操作:
将我们的配置转换为正则表达式
对源码作匹配替换
env文件
读取配置
本质上,该文件也属于配置项,故也在resolveConfig中进行拉取
对于loadEnv函数,接收的三个参数分别为:当前运行环境(devlepment or production)、是否配置是env的目录(默认根目录下)、是否设置了前缀(默认以VITE_开头)
然后借助dotenv包对文件内容做解析
最后将解析到的值挂载到env对象上并返回
挂载