如何解决webpack-dev-server代理常切换问题


Posted in Javascript onJanuary 09, 2019

背景

通常我们有一份webpack.dev.config.js使用webpack-dev-server的proxy,代理到开发服务器,来解决本地跨域问题。假如项目变大,可能需要proxy到不同环境,比如docker,或者后端开发人员的电脑上

现有问题

  • 需要手动更改proxy配置,比较麻烦还容易写错
  • 改变后的config文件会被git检测到
  • 不小心将本地修改的配置push到远程仓库,对其他人造成困扰

需求

假如本地开发服务器是dev.xxx.cn,docker环境是docker.xxx.cn,服务端开发人员ip是192.168.1.1

因为我本地用了gulp,启动前端开发环境到命令是 gulp local (与 npm run xx 的效果差不多),那么我希望

  • 当gulp local的时候,proxy 为 dev.xxx.cn
  • 当gulp local -t docker的时候,proxy 为 docker.xxx.cn
  • 当gulp local -t 192.168.1.1的时候,proxy 为 192.168.1.1

解决方案

创建webpack.local.js,proxy配置如下

proxy: {
 '/api/**': {
  target: 'http://{target|dev}.xxx.cn',
  changeOrigin: true,
 },
}

在我们运行 gulp local 时,读取local.config文件,替换{target|dev}为 -t 后的内容,比如 gulp local -t docker ,替换后变为 'http://docker.xxx.cn'

再将替换后的文件内容输出到一个名为webpack.local.target.js的文件里,然后执行 webpack-dev-server -c webpack.local.target.js

最后修改.gitignore文件,加入webpack.loc.target.js,这样每次生成的文件就不会被误push到远程

实现细节

上面的配置中 {target|dev} |后面的dev是执行 gulp local 时的默认选项

const { t } = gulputil.env
let config = fs.readFileSync(_path.join(__dirname, '/webpack.loc.js')).toString()

if (/\d{1,3}(\.\d{1,3}){3}/.test(t)) {
 config = config.replace(/\\{target[^}]+\\}[^']*/g, t)
} else if (typeof t === 'string' && t.length > 0) {
 config = config.replace(/\\{target[^}]+\\}/g, t)
} else {
 config = config.replace(/\\{target\\|([^}]+)\\}/g, '$1')
}
fs.writeFileSync(_path.join(__dirname, '/webpack.loc.target.js'), config)

第一个if判断内容为-t后的参数是否为ip,如果是,替换 'http://{target|dev}.xxx.cn' 为 http://192.168.1.1

第二个判断是否有参数,如果有,替换为 http://docker.xxx.cn

第三个判断就是直接运行 gulp local 不加 -t 时,替换为 http://dev.xxx.cn

正则不太懂可以看我另一篇文章《正则速记法》

觉得运行开发环境打包慢可以看《webpack性能榨汁机》

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 对象模型 执行模型
Dec 06 Javascript
jQuery列表拖动排列具体实现
Nov 04 Javascript
JS获取农历日期具体实例
Nov 14 Javascript
获取鼠标在div中的相对位置的实现代码
Dec 30 Javascript
js获取checkbox复选框选中的选项实例
Aug 24 Javascript
JavaScript中使用Object.prototype.toString判断是否为数组
Apr 01 Javascript
vue-cli中打包图片路径错误的解决方法
Oct 26 Javascript
基于openlayers4实现点的扩散效果
Aug 17 Javascript
axios拦截设置和错误处理方法
Mar 05 Javascript
JS打印彩色菱形的实例代码
Aug 15 Javascript
微信小程序用户授权、位置授权及获取微信绑定手机号
Jul 18 Javascript
js tab栏切换代码实例解析
Sep 03 Javascript
JavaScript学习笔记之数组基本操作示例
Jan 09 #Javascript
浅谈webpack性能榨汁机(打包速度优化)
Jan 09 #Javascript
Node.js的进程管理的深入理解
Jan 09 #Javascript
从vue源码看props的用法
Jan 09 #Javascript
浅谈关于JS下大批量异步任务按顺序执行解决方案一点思考
Jan 08 #Javascript
vue-cli2 构建速度优化的实现方法
Jan 08 #Javascript
一个因@click.stop引发的bug的解决
Jan 08 #Javascript
You might like
如何开始收听短波广播
2021/03/01 无线电
php+mysql事务rollback&commit示例
2010/02/08 PHP
PHP生成验证码时“图像因其本身有错无法显示”的解决方法
2013/08/07 PHP
PHP实现的随机IP函数【国内IP段】
2016/07/20 PHP
PHP+iframe模拟Ajax上传文件功能示例
2019/07/02 PHP
基于jQuery实现的当离开页面时出现提示的实现代码
2011/06/27 Javascript
JQuery扩展插件Validate 5添加自定义验证方法
2011/09/05 Javascript
jQuery 获取和设置select下拉框的值实现代码
2013/11/08 Javascript
在javascript中实现函数数组的方法
2013/12/25 Javascript
jquery教程限制文本框只能输入数字和小数点示例分享
2014/01/13 Javascript
AngularJS基础 ng-if 指令用法
2016/08/01 Javascript
node.js连接MongoDB数据库的2种方法教程
2017/05/17 Javascript
纯js实现图片匀速淡入淡出效果
2017/08/22 Javascript
你可能不知道的前端算法之文字避让(inMap)
2018/01/12 Javascript
Vue引用第三方datepicker插件无法监听datepicker输入框的值的解决
2018/01/27 Javascript
[03:46]显微镜下的DOTA2第七期——满血与残血
2014/06/20 DOTA
[02:38]DOTA2亚洲邀请赛 IG战队巡礼
2015/02/03 DOTA
[06:06]2018DOTA2亚洲邀请赛主赛事第四日战况回顾 全明星赛欢乐上演
2018/04/07 DOTA
Python 除法小技巧
2008/09/06 Python
Django静态资源URL STATIC_ROOT的配置方法
2014/11/08 Python
用Python的线程来解决生产者消费问题的示例
2015/04/02 Python
Python编程中运用闭包时所需要注意的一些地方
2015/05/02 Python
Python实现Linux命令xxd -i功能
2016/03/06 Python
Python中二维列表如何获取子区域元素的组成
2017/01/19 Python
python win32 简单操作方法
2017/05/25 Python
Python使用线程来接收串口数据的示例
2019/07/02 Python
Pandas实现dataframe和np.array的相互转换
2019/11/30 Python
Python猜数字算法题详解
2020/03/01 Python
简单了解pytest测试框架setup和tearDown
2020/04/14 Python
IntelliJ 中配置 Anaconda的过程图解
2020/06/01 Python
用HTML5的canvas实现一个炫酷时钟效果
2016/05/20 HTML / CSS
加拿大快时尚零售商:Ardene
2018/02/14 全球购物
华为消费者德国官方网站:HUAWEI德国
2020/11/03 全球购物
幼儿园儿童节主持词
2014/03/21 职场文书
大学生社团活动总结
2014/04/26 职场文书
2014群众路线学习笔记
2014/11/06 职场文书