webpack正式、测试环境接口地址本地运行及打包命令配置

声明:本文由w3h5原创,转载请注明出处:《webpack正式、测试环境接口地址本地运行及打包命令配置》 https://www.w3h5.com/post/521.html

为了方便开发,节省接口地址修改维护时间,可以通过 webpack 配置,区分正式、测试环境。

可以方便的通过一个命令或者参数,运行或者连接不同环境的接口地址:

# 本地运行测试环境npm run dev# 本地运行正式环境 npm run prod# 测试环境打包npm run build# 正式环境打包npm run build prod

先了解几个概念:

process.argv :

process 对象是一个全局变量,它提供当前 Node.js 进程的有关信息,以及控制当前 Node.js 进程。 因为是全局变量,所以无需使用 require()。

process.argv 属性返回一个数组,这个数组包含了启动 Node.js 进程时的命令行参数。

其中:

数组的第一个元素 process.argv[0] 返回启动 Node.js 进程的可执行文件所在的绝对路径。

第二个元素 process.argv[1] 为当前执行的 JavaScript 文件路径。

剩余的元素为其他命令行参数。

例如运行:

node process-args.js one two=three four

此时:

process.argv = ['/usr/local/bin/node', '<path>process-args.js', 'one', 'two=three', 'four']

webpack 也同样支持 argv 参数,在 package.json 中配置命令:

"scripts": {    "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",    "prod": "webpack-dev-server --inline --progress --env=prod --config build/webpack.dev.conf.js",  },

我们就可以从process.argv[4] 拿到 "--env=prod" 这个参数。

打印出来的效果如下:

# process.argv[ '/usr/local/bin/node',  '/www/w3h5/node_modules/.bin/webpack',  '--inline',  '--progress',  '--env=prod',  '--config' ]

配置方法:

首先修改 webpack 的配置文件, /config/dev.env.js

'use strict'const merge = require('webpack-merge')const prodEnv = require('./prod.env')let params = process.argv[4]let baseUrl = ''switch (params) {  case '--env=prod': //正式环境地址    baseUrl = '"https://api.w3h5.com/"',//首页地址    break  default: //测试环境地址    baseUrl = '"http://api-test.w3h5.com/"',//首页地址}module.exports = merge(prodEnv, {//process.env.HOME_URL  NODE_ENV: '"development"',  HOME_URL: baseUrl,//首页地址})

先声明一个变量 params ,然后将--env=prod(代表正式环境)赋值给它。

使用switch case 语句进行判断,如果有这个代表正式环境的参数,则使用正式环境的地址。如果没有这个参数,则默认走测试环境。

然后将 HOME_URL变量用 module.exports 导出。

这样就可以通过 npm 命令来区分运行正式还是测试环境了。

# 测试环境npm run dev# 正式环境npm run prod

打包命令配置:

和上面一样,修改  /config/prod.evn.js 文件:

'use strict'let params = process.argv[2]let baseUrl = ''switch (params) {  case 'prod': //正式环境地址    baseUrl = '"https://api.w3h5.com/"',//首页地址    break  default: //测试环境地址    baseUrl = '"http://api-test.w3h5.com/"',//首页地址}module.exports = merge(prodEnv, {//process.env.HOME_URL  NODE_ENV: '"production"',  HOME_URL: baseUrl,//首页地址})

细心的朋友可能会注意到,这里给 params 赋得值是process.argv[2],可以看一下 package.json 中配置的命令:

"scripts": {  "build": "node build/build.js"},

因为 build 命令只有两个参数,执行下面的命令,就可以将第三个参数 prod 带过去:

# 测试环境打包npm run build # 正式环境打包npm run build prod

前端直接调用

项目运行后,前端就可以直接用 process.env.HOME_URL 获取到首页的地址了。

测试环境会显示:http://api-test.w3h5.com/

正式环境就是:https://api.w3h5.com/

什么是 process.env :

通常情况下,我们需要针对不同环境(开发环境、集成环境、生产环境等),进行相应策略的打包(比如是否替换接口地址,代码是否压缩等)。webpack 就是通过 process.env 属性加以区分。

webpack 是 npm 生态中的一个模块,webpack 运行依赖于 node 环境。这里的 process.env 是Nodejs提供的一个API,它返回一个包含用户环境信息的对象。

如果我们给 Nodejs 设置一个环境变量,并把它挂载在 process.env 返回的对象上,便可以在代码中进行相应的环境判断。

process.env 属性返回一个对象,包含了当前 Shell 的所有环境变量。比如,process.env.HOME 返回用户的主目录。

通常的做法是,新建一个环境变量 NODE_ENV ,用它确定当前所处的开发阶段,生产阶段设为 production ,开发阶段设为 development 或 testing ,然后在脚本中读取 process.env.NODE_ENV 即可。

要说明的是,NODE_ENV 这个名称只是开发社区的一种共识,名称内容是可以修改的。如果需要,你也可以把它定义为 NODE_abc 或者 xxx 都行。

参考文献:

http://nodejs.cn/api/process.html#process_process_argv

https://www.jianshu.com/p/19d199f93045

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352