在前端项目中使用自定义的环境变量

在前端项目中使用webpack的环境变量

最近在折腾项目中,有时候会需要在前端项目中使用环境变量,比如在webpack.prod.js或者webpack.dev.js中使用。找了一些解决办法,最后有了这篇文章。

定义环境变量

在根目录下创建.env文件

base.env

env 复制代码
#基础配置,不管开发或者测试环境都用得到,使用CUSTOMIZE前缀,和node的环境变量区分

CUSTOMIZE_APP_TITLE=一个系统

dev.env

env 复制代码
#测试开发环境信息

CUSTOMIZE_PORT=8081

CUSTOMIZE_SERVER_URL='http://localhost:8000'

CUSTOMIZE_MODE='development'

prod.env

env 复制代码
#正式环境信息

CUSTOMIZE_MODE='production'

CUSTOMIZE_PORT=80

CUSTOMIZE_SERVER_URL='~api'

使用环境变量

在webpack中使用

使用dotenv插件直接帮我们加入变量到process.env,同时可以引入多个,并且可以覆盖,详细文档dotenv

js 复制代码
    // webpack.prod.js or webpack.dev.js

    // 省略些代码

    const dotenv = require('dotenv');// 引入插件

    dotenv.config({ path: ['dev.env', 'base.env'], override: true });// 加载.env文件,并且覆盖,

    console.log(process.env.CUSTOMIZE_APP_TITLE);// 一个系统

    // 省略些代码

在前端页面中使用

相对直接在webpack中使用,我们要保证页面编译通过;就需要使用到webpack.DefinePlugin,一个插件把变量注入到全局;

dotenv.config()会返回一个处理好的对象
js 复制代码
// 省略些代码

 const _dotenv = dotenv.config({ path: ['dev.env', 'base.env'], override: true })

 console.log(_dotenv)

 // 省略些代码

 /*{

    parse:{ CUSTOMIZE_APP_TITLE: '一个系统', CUSTOMIZE_MODE: 'development', CUSTOMIZE_PORT: '8081', CUSTOMIZE_SERVER_URL: 'http://localhost:8000' }

 }*/
webpack.DefinePlugin使用方式

webpack.dev.js 里配置

js 复制代码
// 省略些代码

module.exports = {

  plugins: [

    new webpack.DefinePlugin({

      'process.env.CUSTOMIZE_MODE': JSON.stringify('CUSTOMIZE_MODE')

    })

  ]

}

// 省略些代码

在页面中使用

js 复制代码
baseURL: process.env.CUSTOMIZE_MODE === 'production' ? process.env.CUSTOMIZE_SERVER_URL : '/api',
总结一下页面使用

配置

js 复制代码
 // webpack.prod.js or webpack.dev.js

    // 省略

    const dotenv = require('dotenv');// 引入插件

    const _dotenv = dotenv.config({ path: ['dev.env', 'base.env'], override: true });// 加载.env文件,并且覆盖,

    console.log(process.env.CUSTOMIZE_APP_TITLE);// 一个系统

    module.exports = {

        plugins: [

            new webpack.DefinePlugin(generateEnv(_dotenv.parse))

        ]

    }

    /**

     * 根据提供的解析数据生成环境对象。

     *

     * @param {Object} parsed - 解析数据对象。

     * @return {Object} 生成的环境对象。

     */

    function generateEnv(parsed) {

        const env = {};

        Object.keys(parsed).forEach(key => {

            const value = parsed[key];

            if (value && value !== null) {

                env[`process.env.${key}`] = JSON.stringify(value);

            }

        });

        return env;

    }

    // 省略些代码

使用

tsx 复制代码
import { FC } from 'react';

import { Outlet } from 'react-router-dom';

import './index.scss';

  


const User: FC = () => {

    return (

        <div className="user-main">

            <div className="user-container">

                <div className="title">{process.env.CUSTOMIZE_APP_TITLE}</div>

                <Outlet />

            </div>

        </div>

    );

};

export default User;

注意:如果使用了ts,可能会出现报错 process is not defined

定义一下全局ts类型

ts 复制代码
declare const process: {

    env: {

        [key: string]: string;

    };

    [key: string]: unknown;

};

谢谢观看🙂️

相关推荐
小鱼神10246 小时前
自动扣webpack框架演示 | 某书 x-xray-traceid 签名算法分析记录
webpack·js逆向·扣代码·xhs
16年上任的CTO1 天前
一文大白话讲清楚webpack基本使用——6——热更新及其原理
前端·webpack·node.js·热更新·hmr·热重载
16年上任的CTO1 天前
一文大白话讲清楚webpack基本使用——1——完成webpack的初步构建
前端·webpack·node.js
Nejosi_念旧1 天前
包文件分析器 Webpack Bundle Analyzer
前端·webpack·node.js
fechild1 天前
npm和webpack学习
学习·webpack·npm
16年上任的CTO2 天前
一文大白话讲清楚webpack基本使用——2——css相关loader的配置和使用
前端·webpack·node.js·sass-loader·css-loader·style-loader
16年上任的CTO2 天前
一文大白话讲清楚webpack基本使用——4——vue-loader的配置和使用
前端·javascript·webpack·ecmascript·vue-loader·vueloaderplugin
16年上任的CTO2 天前
一文大白话讲清楚webpack基本使用——9——预加载之prefetch和preload以及webpackChunkName的使用
前端·webpack·node.js·webpack preload·prefetch
漂流瓶jz2 天前
谈一谈前端构建工具的本地代理配置(Webpack与Vite)
前端·webpack·node.js·vite·proxy·代理