vue项目配置不同环境打包指令(vue-cli2、vue-cli3项目)

news2024/12/23 2:22:17

目录

  • 一、vue-cli3项目:
      • 1、项目根目录创建环境文件
      • 2、 配置打包指令
      • 3、打包生成不同的dist文件夹
  • 二、vue-cli2项目
      • 1、配置指令
      • 2.创建环境文件
      • 3、config/index.js中添加
  • 三、遇到的问题
      • 1.vue-cli3项目配置打包指令,没有生成css文件--mode test
      • 2、vue-cli3生成css/js文件生成名称和默认打包指令生成的不一样
      • 3、env.test 使用test导报会有问题

一、vue-cli3项目:

1、项目根目录创建环境文件

.env.环境名,
例如
.env.dev 开发环境
.env.test 测试环境
.env.prod 生产环境

.env.dev内容可如下:

NODE_ENV =  dev  // 和文件名一致
VUE_APP_XX = XXX // VUE_APP为前缀,后面名称可自定义
VUE_APP_BASE_API = http://10.1.0.100:8000

BASE_URL 默认的参数
默认VUE_APP_XX 为全局变量, 可通过process.env 获取到包含这些参数的一个对象。
在这里插入图片描述

  • .env.prod 内容如下
NODE_ENV = 'production'
VUE_APP_ENV = 'prod'
VUE_APP_BASE_API = http://ss.demo.s.com:8000
VUE_APP_BUSY_API = http://ss.demo.s.com:8001
VUE_APP_WS_API = ws://ss.demo.s.com:8001/zssSocket

注意: NODE_ENV = ‘production’ 一定要给 production

  • .env.test内容如下
NODE_ENV = 'production'
VUE_APP_ENV = 'test'
VUE_APP_BASE_API = http://test.s.com:8000
VUE_APP_BUSY_API = http://test.s.com:8001
VUE_APP_WS_API = ws://test.s.com:8001/zssSocket
  • .env.dev内容如下
NODE_ENV = 'dev'
VUE_APP_ENV = 'dev'
VUE_APP_BASE_API = http://test.s.com:8000
VUE_APP_BUSY_API = http://test.s.com:8001
VUE_APP_WS_API = ws://test.s.com:8001/zssSocket

2、 配置打包指令

package.json 的scripts对象中
增加--mode XX(XX为环境配置文件名, 如上面的dev、test、prod)变为:
"serve": "vue-cli-service serve --mode dev ",
"build:test": "vue-cli-service build --mode test",
"build:prod": "vue-cli-service build --mode prod"

3、打包生成不同的dist文件夹

可以在环境配置文件 .env.test / .env.prod 中添加VUE_APP_XX 定义打包文件夹名称,也可以根据process.env.NODE_ENV 的值判断给不同文件名。

vue.config.js 给不同dist文件夹名称, 增加配置:

const outputDir = process.env.NODE_ENV ? "zcc-dist" + process.env.NODE_ENV : "dist"

module.exports = defineConfig({
     outputDir: outputDir,// 新增配置
     devServer: {}
})

二、vue-cli2项目

1、配置指令

"dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
"start": "npm run dev",
"build": "cross-env NODE_ENV=production env_config=prod node build/build.js",
"build:test": "cross-env NODE_ENV=production env_config=test node build/build.js",
"build:prod": "cross-env NODE_ENV=production env_config=prod node build/build.js"

2.创建环境文件

/config 文件夹创建环境文件:
dev.env.js
prod.env.js
test.env.js

prod.env.js内容如下:

'use strict'
module.exports = {
    NODE_ENV: '"production"',
    ENV_CONFIG: '"prod"',
    API_ROOT: '"http://kms.demo.xx.com:8000"',
    BUSY_API_ROOT: '"http://kms.demo.xx.com:8001"'
}

其他地方使用: process.env.API_ROOT

3、config/index.js中添加

prodEnv: require("./prod.env"), // 演示、生产
testEnv: require("./test.env"),// 测试环境

在这里插入图片描述

三、遇到的问题

1.vue-cli3项目配置打包指令,没有生成css文件–mode test

解决:
vue.config.js 中增加:

module.exports = {
css: {extract: true}, // 增加这行
devServer: {}
}

再次运行打包指令, 生成css文件正常。

2、vue-cli3生成css/js文件生成名称和默认打包指令生成的不一样

  • 默认指令npm run build 生成的
    在这里插入图片描述
  • “build:test”: “vue-cli-service build --mode test”,
    “build:prod”: “vue-cli-service build --mode prod”
    打包生成的
    在这里插入图片描述
    如果想要生成和npm run build默认一样的话,NODE_ENV 要设置成NODE_ENV = production

3、env.test 使用test导报会有问题

生成的css和js都只有一个文件 且js文件比较大。
查了下,说用test会有影响, 改成testing就好了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/430288.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

UE DTMqtt 虚幻引擎 Mqtt 客户端插件说明

目录 CreateMqttClient Connect Subscribe UnSubscribe Publish Disconnect BindConnectedDelegate BindConnectionLostDelegate BindMessageDelegate CreateMqttClient 创建一个Mqtt客户端对象 Connect 链接Mqtt服务器Subscribe 订阅消息频道UnSubscribe 取消订阅频道…

【go项目-geecache】动手写分布式缓存 - day3 - HTTP 服务端

收获总结: 了解go函数的可变参数的使用,还有切片展开的方式即…了解了HTTP通信方式,hinder的使用了解了go.mod ,import 和modoule的使用 分布式缓存需要实现点对点的通信,我们可以使用HTTP来实现节点之间的通信&…

Linux·IO子系统和文件系统读写流程

目录 1.概述 2.linux IO子系统和文件系统读写流程 3.IO之流程与buffer概览 4.IO队列和IO调度 1.概述 分析一下写操作: char *buf malloc(MAX_BUF_SIZE); strncpy(buf, src, , MAX_BUF_SIZE); fwrite(buf, MAX_BUF_SIZE, 1, fp); fclose(fp); 以下图为例&…

九耶丨钛伦特-用深度学习实现垃圾图像分类(二)

3 构建模型 这里大家可以使用自己在项目 2 中寻找到的最好的模型结构,做为示例,这里以实验2-3 中的 snet 模型为基础,并进行细微的调整。 样例代码: 需要注意的是,我们在第一层卷基层之后增加了一层池化层,主要是为了降…

大数据技术之Spark

第1章 Spark概述 1.1 什么是Spark 回顾:Hadoop主要解决,海量数据的存储和海量数据的分析计算。 Spark是一种基于内存的快速、通用、可扩展的大数据分析计算引擎。 Hadoop的Yarn框架比Spark框架诞生的晚,所以Spark自己也设计了一套资源调度…

30天学会《Streamlit》(1)

30学会《Streamlit》是一项编码挑战,旨在帮助您开始构建Streamlit应用程序。特别是,您将能够: 为构建Streamlit应用程序设置编码环境 构建您的第一个Streamlit应用程序 了解用于Streamlit应用程序的所有很棒的输入/输出小部件 第1天 - 建立…

Java面向对象高级【注解和反射】

目录 注解 什么是注解? 自定义注解 元注解 反射 什么是反射 静态语言和动态语言 动态语言 静态语言 对比 Class类 Java内存分析 类加载过程 类加载器 获取运行时类的完整结构 通过Class对象实例化对象 1.调用Class对象的newInstance 2.Constructor…

保姆级教程!如何在 Anolis 8 上构建基于 Nydus 和 Dragonfly 的镜像加速解决方案?

文/云原生 SIG 01 背景 镜像是容器技术的基础之一,在云原生场景下,业务的正常运作离不开对镜像的制作、分发和运行。当前的镜像在使用的过程中,需要将镜像从仓库中全量拉取到本地,再由容器 engine 进行解压,堆叠挂载…

【JUC进阶】详解synchronized锁升级

文章目录 1. synchronized概述2. synchronized 的实现原理2.1 Java对象组成2.2 Monitor2.3 从字节码角度看synchronized 3. 锁升级3.1 偏向锁3.2 轻量级锁 1. synchronized概述 synchronized是一个悲观锁,可以实现线程同步,在多线程的环境下&#xff0c…

信盈达CorexM4核心板STM32F407VGT6电路原理图\电源原理图\USB的工作原理\miniUSB的分类

一、电源部分电路 Micro_USB插座中的5V与GND就是直接提供VCC与GND,其中的D与D-是接在CH340芯片上的实现串口通信的数据口。 电源VCC通过一个自恢复保险丝接在一个自锁开关上,这样就分析完一个miniUSB的提供电源的原理图了。 在原理图的右上角有一个AMS1117-3.3的器件…

RabbitMQ 高级篇 | 黑马

一、消息可靠投递 生产端的 在使用 RabbitMQ的时候,作为消息发送方希望杜绝任何消息丢失或者投递失败场景。 RabbitMQ 为我们提供了两种方式用来控制消息的投递可靠性模式。 confirm 确认模式return 退回模式 rabbitmq整个消息投递的路径为: producer--->ra…

HCIP-6.6BGP配置中IGP路由表和BGP路由表、IP路由表关系

BGP配置中IGP路由表和BGP路由表、IP路由表关系1、基础配置2、配置建立IBGP对等体3、配置EBGP对等体4、使用network命令宣告路由5、路由的学习5.1、R2的路由表5.2、R1的BGP路由表5.3、R3的BGP路由表5.4、R5的BGP路由表6、AS200与AS100通信6.1、AS200出接口注入AS100IP路由表6.2、…

Go 汇编详解

动手点关注干货不迷路前言我们知道 Go 语言的三位领导者中有两位来自 Plan 9 项目,这直接导致了 Go 语言的汇编采用了比较有个性的 Plan 9 风格。不过,我们不能因咽废食而放弃无所不能的汇编。1、 Go 汇编基础知识1.1、通用寄存器不同体系结构的 CPU&…

【Docker】使用Docker Compose部署项目

目录 前言 使用 前言 如果你部署项目需要很多个容器, 并且还是在手动一个一个启动的话来试试Docker Compose, 只需要写好Docker Compose文件运行命令就能帮你一次性全启动, 对微服务很友好啊~ 使用 运行以下命令查看是否有版本号, 确保你已经安装了Docker Compose docker…

使用sealos工具部署k8s

为什么使用sealos工具:简单、快、完全兼容 k8s、给100年认证 sealos使用最新版本: 官网:https://www.sealyun.com/ 码:https://github.com/labring/sealos 官方介绍什么是sealos Sealos 是以 kubernetes 为内核的云操作系统发行版…

精彩回顾|4.8 Beijing Rust Meetup

2023年4月8日,达坦科技联合南京大学、CloudWeGo、华为等技术专家成功举办了题为Rust X的meetup。开发者们不仅线下积极报名参与,更在线上直播中踊跃参与互动,一起探讨Rust作为一种强调性能、安全和并发性的编程语言的各种应用和实践。演讲者与…

从EXCEL BOM 描述中提取部分信息---正则表达式使用

从EXCEL BOM描述中提取关键的信息,用于建库填写内容,或者检查BOM等都会用到,如下大概通过两种方式实现信息的提取 1.手动Excel中提取 2.将如上1的方式用python实现,可以实现批量操作,减少操作带来的错误,…

[网络安全]第三次作业

目录 1. 什么是IDS? 2. IDS和防火墙有什么不同? 3. IDS工作原理? 4. IDS的主要检测方法有哪些详细说明? 5. IDS的部署方式有哪些? 6. IDS的签名是什么意思?签名过滤器有什么作用?例外签名…

温故c语言——深度剖析数据在内存中的存储

目录 数据类型详细介绍整形在内存中的存储:原码、反码、补码大小端字节序介绍及判断浮点型在内存中的存储解析 1. 数据类型介绍 基本内置数据类型有: //在内存中占用空间的大小 char //字符数据类型 占用1个字节 short //短整型 占用2个…

linux及openEuler破解root密码

第一步:开机的时候按键盘的字母 E 键, 进入引导模式 第二步:进入引导模式 :找到linux这一行,按键盘上的end 键,跳转到行尾,输入: init/bin/sh 修改完后,按键盘上的 ctr…