如何解决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 相关文章推荐
DLL+ ActiveX控件+WEB页面调用例子
Aug 07 Javascript
JavaScript 参数中的数组展开 [译]
Sep 21 Javascript
javascript中声明函数的方法及调用函数的返回值
Jul 22 Javascript
jquery.ajax之beforeSend方法使用介绍
Dec 08 Javascript
javascript中checkbox使用方法实例演示
Nov 19 Javascript
微信小程序获取用户openId的实现方法
May 23 Javascript
深入浅出webpack教程系列_安装与基本打包用法和命令参数详解
Sep 10 Javascript
bootstrap table方法之expandRow-collapseRow展开或关闭当前行数据
Aug 09 Javascript
微信小程序自定义组件之可清除的input组件
Jul 17 Javascript
记一次webapck4 配置文件无效的解决历程
Sep 19 Javascript
解决layer弹出层中表单不起作用的问题
Sep 09 Javascript
vue 父组件通过v-model接收子组件的值的代码
Oct 27 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
社区(php&&mysql)一
2006/10/09 PHP
PHP脚本的10个技巧(8)
2006/10/09 PHP
PHP生成随机用户名和密码的实现代码
2013/02/27 PHP
2款PHP无限级分类实例代码
2015/11/11 PHP
PHP定义字符串的四种方式详解
2018/02/06 PHP
jQuery 无限级菜单的简单实例
2014/02/21 Javascript
jQuery.parseJSON(json)将JSON字符串转换成js对象
2014/07/27 Javascript
JS解析XML文件和XML字符串详解
2015/04/17 Javascript
Node.js编程中客户端Session的使用详解
2015/06/23 Javascript
基于chosen插件实现人员选择树搜索自动筛选功能
2016/09/24 Javascript
JS不完全国际化&本地化手册 之 理论篇
2016/09/27 Javascript
JS回调函数简单用法示例
2017/02/09 Javascript
angularJs自定义过滤器实现手机号信息隐藏的方法
2018/10/08 Javascript
vue-cli V3.0版本的使用详解
2018/10/24 Javascript
Jquery和CSS实现选择框重置按钮功能
2018/11/08 jQuery
jQuery AJAX与jQuery事件的分析讲解
2019/02/18 jQuery
vue组件之间通信方式实例总结【8种方式】
2019/02/22 Javascript
微信小程序实现的五星评价功能示例
2019/04/25 Javascript
Vue实现多标签选择器
2019/11/28 Javascript
[46:14]完美世界DOTA2联赛PWL S3 Magma vs INK ICE 第一场 12.11
2020/12/16 DOTA
python简单程序读取串口信息的方法
2015/03/13 Python
Python 40行代码实现人脸识别功能
2017/04/02 Python
python实现随机森林random forest的原理及方法
2017/12/21 Python
PyTorch CNN实战之MNIST手写数字识别示例
2018/05/29 Python
python全栈要学什么 python全栈学习路线
2019/06/28 Python
Python Tornado之跨域请求与Options请求方式
2020/03/28 Python
利用canvas实现图片压缩的示例代码
2018/07/17 HTML / CSS
canvas绘制圆角头像的实现方法
2019/01/17 HTML / CSS
迟到检讨书300字
2014/02/14 职场文书
健康家庭事迹材料
2014/05/02 职场文书
十佳好少年事迹材料
2014/08/21 职场文书
企业介绍信范文
2015/01/30 职场文书
银行自荐信范文
2015/03/25 职场文书
学校财务管理制度
2015/08/04 职场文书
Vue图片裁剪组件实例代码
2021/07/02 Vue.js
python数字图像处理:图像的绘制
2022/06/28 Python