vue+webpack怎么分环境进行打包
这里说下,webpack打包里面涉及到的东西,不止webpack,还有node的知识,
node的全局变量process,process.env用于返回用户环境信息对象,因为是node的全局变量,所以无需使用reqiure进行引入。
网上很多人说:npm_lifecycle_event变量是返回当前正在运行的脚本名称,pretest、test、posttest。其实就是代表当前执行循环的哪个阶段,参考链接:https://segmentfault.com/a/1190000008832423
打印这个process.env,如下图所示:

可以看到加上的变量_BASEURL已经生效,这是在dev环境下面进行打印的,test和prod环境是看不到的,只能是在打包文件中查看。
然后呢,在开发源码中,我们进行判断这个声明周期环境变量,这个是sf公司埋点的插件文件(如果没有涉及可以不用管):
/**
* 相应的生产地址和测试环境地址
*/
SfGather.url =
process.env.npm_lifecycle_event !== 'build'
? 'http://218.17.248.243:40021/json_data'
: 'https://inc-ubas-web.sf-express.com/json_data'
console.log('SfGather.url ' + SfGather.url)
如果是build就用生产环境,如果不是,就用测试环境,这个是埋点的测试和生产环境的一个区分,那么同理,我们Axios请求一样的,在源码中:
axios.defaults.baseURL = process.env._BASEURL + '/api/v1/'
Vue.prototype.$axios = axios
process.env对象中添加env_BASEURL(名字可自定义),该变量已经在prod.env.js+request.json中定义。
在build.js中,我们把它设置为:
process.env.NODE_ENV = 'production'
在package.json中:
"scripts": {
"dev": "node build/dev-server.js",
"start": "npm run dev",
"test": "node build/build.js",
"build": "node build/build.js"
},
然后在config/prod.env.js中:
'use strict'
const URL = require('./request.json');
const target = process.env.npm_lifecycle_event
let obj = {}
if(target === 'test') {
obj = {
NODE_ENV: '"production"',
_BASEURL: `'${URL.test.baseURL}'`
}
console.log('yeah')
} else {
obj = {
NODE_ENV: '"production"',
_BASEURL: `'${URL.prd.baseURL}'`
}
}
module.exports = obj;
在config添加文件request.json
{
"dev":{
"baseURL": "http://localhost:8088"
},
"test":{
"baseURL": "http://sfim-common.sit.sf-express.com/sfimecsauth/workboard"
},
"prd":{
"baseURL": "http://sfim-mcommon.sf-express.com/sfimecsauth/workboard"
}
}
所以关键点在哪里?首先是npm scripts里面进行指令的添加,然后再进行环境变量的赋值区分,在node的process.env对象中添加baseURL,就是这么简单。
当你选择了一种语言,意味着你还选择了一组技术、一个社区。——Joshua Bloch【完】
vue+webpack怎么分环境进行打包的更多相关文章
- windows环境下搭建vue+webpack的开发环境
前段时间一直在断断续续的看vue的官方文档,后来就慢慢的学习搭建vue的开发环境,已经有将近两周了,每到最后一步的时候就会报错,搞的我好郁闷,搁置了好几天,今天又接着搞vue的开发环境,终于成功了.我 ...
- vue + webpack + gulp 简单环境 搭建
一.物料准备 废话不多说,直接上 package.json { "name": "vwp", "version": "1.0.0& ...
- Vue + Webpack 根据不同环境打包
修改 prod.env.js // 当前正在运行的脚本名称 const TARGET = process.env.npm_lifecycle_event // 第一个参数 let argv = pro ...
- windows下搭建vue+webpack的开发环境
1. 安装git其右键git bash here定位比cmd的命令行要准确,接下来的命令都是利用git bash here.2. 安装node.js一般利用vue创建项目是要搭配webpack项目构建 ...
- windows下vue+webpack前端开发环境搭建及nginx部署
一.开发环境搭建 1.前端框架一般都依赖nodejs,我们首先要安装node.js.请参考http://www.cnblogs.com/wuac/p/6381819.html. 2.由于许多npm的源 ...
- Spring boot项目分环境Maven打包,动态配置文件,动态配置项目
Spring boot Maven 项目打包 使用Maven 实现多环境 test dev prod 打包 项目的结构 在下图中可用看出,我们打包时各个环境需要分开,采用 application-环境 ...
- Windows 环境下vue+webpack前端开发环境搭建
一.开发环境搭建 1.前端框架一般依赖node.js,我们首先要安装node.js. 2.由于许多npm 的源都在国外的地址,安装起来特别慢,所以我们这里利用淘宝的镜像服务器. 安装命令为:npm i ...
- windows环境下安装vue+webpack的开发环境
本人最近在学习vue,在学习的过程中遇到对的问题和解决方法 1.我们首先要安装node.js.node.js的官方地址为:https://nodejs.org/en/download/,下载完毕,按照 ...
- Vue项目分环境打包的实现步骤
转:https://blog.csdn.net/xinzi11243094/article/details/80521878 方法一:亲测真的有效 在项目开发中,我们的项目一般分为开发版.测试版.Pr ...
随机推荐
- IPC之——信号量集
信号量集用于对存在竞争的资源加锁 1.semId=semget(key,nsems,semflg) key:为信号量集名称,可以指定为0455等数字,也可以为PC_PRIVATE nsems:创建几个 ...
- P2967 [USACO09DEC]视频游戏的麻烦Video Game Troubles
冲刺阶段的首篇题解! 题目链接:P2967 [USACO09DEC]视频游戏的麻烦Video Game Troubles: 题目概述: 总共N个游戏平台,金额上限V元,给出每个游戏平台的价钱和其上游戏 ...
- 前端-jQuery-长期维护
############### jQuery简介 ################ jQuery这是非常重要的,在django项目中大量的前端都是使用jQuery进行操作 为什么要学习 ...
- STL:map中的lower_bound和upper_bound
今天在做leetcode的Longest Increasing Subsequence题目时,需要用到二分查找,于是翻看了<STL源码剖析>这本书,发现map里面有lower_bound和 ...
- JVM 的内存布局
这是jdk7以后的版本 1. Heap(堆区) Heap OOM 障最主要的发源地, 它存储着几乎所有的实例对象, 堆由垃圾收集器自动回收, 堆区由各子线程共享使用.通常情况下 它占用的空间是所有内存 ...
- Java基础 带你深刻理解自动装箱,拆箱含义
1.什么是装箱,什么是拆箱装箱:把基本数据类型转换为包装类.拆箱:把包装类转换为基本数据类型.基本数据类型所对应的包装类:int(几个字节4)- Integerbyte(1)- Byteshort(2 ...
- cashier|gasoline|reservoir
N-COUNT 出纳(员);收银员A cashier is a person who customers pay money to or get money from in places such a ...
- css3 - transform, transition 与 translate
零.序言 css 3 的新特性,很多都停留在听说而非实际使用.transform, transition, translate 这三长得实在太像,刚开始的时候总是迷迷糊糊,分不清它们的功能.而最近新接 ...
- python3下scrapy爬虫(第二卷:初步抓取网页内容之直接抓取网页)
上一卷中介绍了安装过程,现在我们开始使用这个神奇的框架 跟很多博主一样我也先选择一个非常好爬取的网站作为最初案例,那么我先用屌丝必备网站http://www.shaimn.com/xinggan/作为 ...
- Java找出两个链表的第一个公共节点
题目描述输入两个链表,找出它们的第一个公共结点. 我的思路:因为是链表,长度都是未知的,不能盲目的两个一起开始自增判断. 首先需要得到 L1的长度 和 L2的长度,让较长的那个先走 (length1- ...