Vue项目如何根据不同运行环境打包项目

 更新时间:2024年03月08日 09:55:13   作者:小破孩呦  
这篇文章主要介绍了Vue项目如何根据不同运行环境打包项目问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

场景

在开发过程中,通常会遇到这样的问题:

在开发环境、测试环境和生产环境中我们会用到不一样的服务接口

在生产环境出现了出现了某个bug,但是在测试环境不存在,这时候就需要开发环境访问生产环境的接口

多端一体的项目模式

这些情况都要手动去切换接口地址,这样会很麻烦,有时还可能出现操作失误。

这时候就需要用到cross-env进行分环境配置了,根据不同的环境,我们使用对应的接口,这样也就不用手动去操作。

第一步 安装依赖 cross-env

使用 cross-env 解决跨平台问题。

在终端运行:

npm install cross-env --save-dev  // 安装 cross-env 依赖

第二步 修改 package.json 文件

在 package.json 中 scripts 属性中 build 命令替换为:

"scripts": {
    "serve": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "build:test": "cross-env vue-cli-service build --mode test",
    "build:prod": "cross-env vue-cli-service build --mode production",
},

当我们需要配置多个环境变量时,未避免package.json命令过长,这时候就可以选择模式配置

默认模式

vue-cli项目下默认有三种模式:

  • development模式:在 vue-cli-service serve 时使用。
  • production模式:在 vue-cli-service build 和 vue-cli-service test:e2e 时使用。
  • test模式:在 vue-cli-service test:unit 时使用。

每个模式都会将 NODE_ENV设置为模式的名称,比如在development模式下,NODE_ENV为 ‘development’。

自定义模式

自定义模式需要通过.env文件进行配置,.env文件分为以下类型:

  • .env,在所有的环境中被载入
  • .env.local,在所有的环境中被载入,但会被 git 忽略
  • .env.[mode],只在指定的模式中被载入
  • .env.[mode].local,只在指定的模式中被载入,但会被 git 忽略
  • [mode] 是自定义的模式名称

例:通过在package.json脚本中增加 --mode [mode]来指定模式。

// package.json
{
  "scripts": {
      "build:testing": "cross-env vue-cli-service build --mode testing",
  }
}

第三步 创建不同环境的文件

在项目根目录新建  .env.development文件:

// 开发环境模式 
// 环境变量
NODE_ENV=development
// 以 VUE_APP_ 开头的变量会被 webpack.DefinePlugin 静态嵌入到客户端侧的包中
VUE_APP_ENV = 'development'

在项目根目录新建  .env.test文件:

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

在项目根目录新建  .env.production文件:

// 线上环境模式
// 环境变量
NODE_ENV=production
// 以 VUE_APP_ 开头的变量会被 webpack.DefinePlugin 静态嵌入到客户端侧的包中
VUE_APP_ENV = 'production'

第四步 根据配置进行判断使用不同的环境服务

let baseUrl = '';
let env = process.env;
 
if (env.VUE_APP_ENV === 'development') {
    baseUrl = `http://xxx/`; // 本地服务地址
} else if(env.VUE_APP_ENV === 'production'){
    baseUrl = `http://xxx/`; // 正式环境服务地址
}else if(env.VUE_APP_ENV === 'test'){
    baseUrl = `http://xxx/`; // 测试环境服务地址
}
export {
    baseUrl,
    env
}

第五步 打包项目

// 测试环境打包项目
npm run build:test
 
// 生产环境打包项目
npm run build:prod

结果测试:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue轻量级框架无法获取到vue对象解决方法

    vue轻量级框架无法获取到vue对象解决方法

    这篇文章主要介绍了vue轻量级框架无法获取到vue对象解决方法相关知识点,有需要的读者们跟着学习下。
    2019-05-05
  • vue.js利用Object.defineProperty实现双向绑定

    vue.js利用Object.defineProperty实现双向绑定

    这篇文章主要为大家详细介绍了vue.js利用Object.defineProperty实现双向绑定,帮大家解析神秘的Object.defineProperty方法
    2017-03-03
  • Vue实现电商网站商品放大镜效果示例

    Vue实现电商网站商品放大镜效果示例

    这篇文章主要为大家介绍了Vue实现电商网站商品放大镜效果示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 在vue-cli创建的项目中使用sass操作

    在vue-cli创建的项目中使用sass操作

    这篇文章主要介绍了在vue-cli创建的项目中使用sass操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • vue里input根据value改变背景色的实例

    vue里input根据value改变背景色的实例

    今天小编就为大家分享一篇vue里input根据value改变背景色的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • 深入浅析Vue.js中 computed和methods不同机制

    深入浅析Vue.js中 computed和methods不同机制

    这篇文章给大家介绍了Vue.js中 computed和methods不同机制,在vue.js中,methods和computed两种方式来动态当作方法使用,文中还给大家提到了computed和methods的区别,感兴趣的朋友一起看看吧
    2018-03-03
  • vue中table表头单元格合并(附单行、多级表头代码)

    vue中table表头单元格合并(附单行、多级表头代码)

    本文主要介绍了vue中table表头单元格合并(附单行、多级表头代码),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • vue+xlsx实现表格的导入导出功能

    vue+xlsx实现表格的导入导出功能

    这篇文章主要介绍了vue+xlsx实现表格的导入导出功能,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-11-11
  • vue3中effect函数到底是什么详解

    vue3中effect函数到底是什么详解

    Effect几乎是Vue3.0中最重要的一个功能了,计算属性监听函数都是基于effect实现的,下面这篇文章主要给大家介绍了关于vue3中effect函数到底是什么的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-06-06
  • Vue2和Vue3如何使用watch侦听器详解

    Vue2和Vue3如何使用watch侦听器详解

    这篇文章主要介绍了在Vue2和Vue3中如何使用watch侦听器,分别对vue2及vue3作了详细的说明,有需要的朋友可以借鉴参考下,希望能够有所帮助
    2021-09-09

最新评论