zoukankan      html  css  js  c++  java
  • vue-cli-service build 不同环境配置

    背景

    在项目部署时,我们需要在测试环境和生产环境使用不同的变量。
    vue-cli提供了vue-cli-service build打包命令,然而vue-cli-service build默认的环境变量值则为production。那我们通过npm run build打包构建,想要实现不同环境使用不同变量,暂时不能实现。

    vue-cli-service介绍

    vue-cli-service介绍
    vue-cli生成项目时,在package.json中会设置:

      "scripts": {
        "serve": "vue-cli-service serve",
        "build": "vue-cli-service build"
    }
    

    vue-cli-service serve 命令会启动一个开发服务器,默认指定的环境模式为development
    vue-cli-service build 会在 dist/ 目录产生一个可用于生产环境的包,带有 JS/CSS/HTML 的压缩,和为更好的缓存而做的自动的 vendor chunk splitting

    环境变量和模式

    在项目的根目录下我们可以创建不同模式的文件:

    .env                # 在所有的环境中被载入
    .env.local          # 在所有的环境中被载入,但会被 git 忽略
    .env.[mode]         # 只在指定的模式中被载入
    .env.[mode].local   # 只在指定的模式中被载入,但会被 git 忽略
    

    一般来说,我们会存在本地环境测试环境线上环境,那我们就需要创建三个模式文件。

    • .env.development开发环境模式
    // 环境变量
    NODE_ENV=development
    // 以 VUE_APP_ 开头的变量会被 webpack.DefinePlugin 静态嵌入到客户端侧的包中
    VUE_APP_ENV = 'development'
    
    • .env.test测试环境模式
    // 环境变量(这里的环境变量是跟打包有关的,production则会进行压缩代码等,真正跟每个环境有关的变量是下面以VUE_APP开头的变量)
    NODE_ENV=production
    // 以 VUE_APP_ 开头的变量会被 webpack.DefinePlugin 静态嵌入到客户端侧的包中
    VUE_APP_ENV = 'test'
    
    • .env.production线上环境模式
    // 环境变量
    NODE_ENV=production
    // 以 VUE_APP_ 开头的变量会被 webpack.DefinePlugin 静态嵌入到客户端侧的包中
    VUE_APP_ENV = 'production'
    

    配置不同模式

    部署时,构建打包执行npm run build,则会执行vue-cli-service build,默认模式为production,对应.env.production文件,取此文件中的环境变量。

    想要配置测试环境,需要在scripts下增加脚本:

    "scripts": {
        "serve": "vue-cli-service serve",
        "build": "vue-cli-service build",
        "build-test": "vue-cli-service build --mode test"
    }
    

    测试环境打包构建时,执行npm run build-test即可。

    index.html使用环境变量

    index.html中可通过<%= process.env.VUE_APP_xxx %>的方式获取不同模式下配置的环境变量。

    验证

    可通过不同模式下对应的环境变量,判断是否为对应的环境

  • 相关阅读:
    Vue3.0 是如何变得更快的?
    阿里云 Centos7 安装mongodb
    ASP.Net Core5.0 EF Core使用记录
    MongoDB批量更新|按条件更新SQL|批量删除某个字段
    Layui单元格编辑获取修改前的值
    判断字符串出现的多个位置
    原生JavaScript的DOM操作汇总
    @Value值为null、#和$的区别
    Dubbo推荐用法
    Dubbo 服务化最佳实践
  • 原文地址:https://www.cnblogs.com/eyunhua/p/14121161.html
Copyright © 2011-2022 走看看