如何解决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 相关文章推荐
用roll.js实现的图片自动滚动+鼠标触动的特效
Mar 18 Javascript
JS 加入收藏夹的代码(主流浏览器通用)
May 13 Javascript
单击复制文字兼容各浏览器的完美解决方案
Jul 04 Javascript
js输入框邮箱自动提示功能代码实现
Dec 10 Javascript
js控制多图左右滚动切换效果代码分享
Aug 26 Javascript
Vue.js常用指令之循环使用v-for指令教程
Jun 27 Javascript
vue项目使用axios发送请求让ajax请求头部携带cookie的方法
Sep 26 Javascript
vue-router实现嵌套路由的讲解
Jan 19 Javascript
微信小程序swiper禁止用户手动滑动代码实例
Aug 23 Javascript
JS如何把字符串转换成json
Feb 21 Javascript
JS实现拖动模糊框特效
Aug 25 Javascript
vue 获取元素额外生成的data-v-xxx操作
Sep 09 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中var_dump,var_export,print_r三个函数的区别
2013/06/21 PHP
php过滤HTML标签、属性等正则表达式汇总
2014/09/22 PHP
php使用fsockopen函数发送post,get请求获取网页内容的方法
2014/11/15 PHP
php实现用手机关闭计算机(电脑)的方法
2015/04/22 PHP
详解PHP队列的实现
2019/03/14 PHP
Thinkphp5框架异常处理操作实例分析
2020/06/03 PHP
又一个图片自动缩小的JS代码
2007/03/10 Javascript
jQuery开发者都需要知道的5个小技巧
2010/01/08 Javascript
javascript函数声明和函数表达式区别分析
2014/12/02 Javascript
JS实现超过长度限制后自动跳转下一款文本框的方法
2015/02/23 Javascript
javascript实现仿腾讯游戏选择
2015/05/14 Javascript
常用jQuery代码分享
2015/07/14 Javascript
JQuery ztree 异步加载实例讲解
2016/02/25 Javascript
浅谈Node异步编程的机制
2017/10/18 Javascript
浅谈React和Redux的连接react-redux
2017/12/04 Javascript
vue.js 微信支付前端代码分享
2018/02/10 Javascript
如何用webpack4.0撸单页/多页脚手架 (jquery, react, vue, typescript)
2019/06/18 jQuery
[01:03:36]DOTA2-DPC中国联赛 正赛 VG vs Magma BO3 第二场 1月26日
2021/03/11 DOTA
用Python编写一个国际象棋AI程序
2014/11/28 Python
Python THREADING模块中的JOIN()方法深入理解
2015/02/18 Python
Python类的动态修改的实例方法
2017/03/24 Python
深入理解Python3中的http.client模块
2017/03/29 Python
Python元组及文件核心对象类型详解
2018/02/11 Python
python中的tcp示例详解
2018/12/09 Python
python日期与时间戳的各种转换示例
2020/02/12 Python
Python批量安装卸载1000个apk的方法
2020/04/10 Python
Python爬取股票信息,并可视化数据的示例
2020/09/26 Python
Python datetime模块的使用示例
2021/02/02 Python
意大利灯具购物网站:Lampade.it
2018/10/18 全球购物
继承时候类的执行顺序问题,一般都是选择题,问你将会打印出什么?
2015/11/18 面试题
成人毕业生自我鉴定
2013/10/18 职场文书
万能检讨书
2015/01/27 职场文书
员工手册编写范本
2015/05/14 职场文书
生产车间管理制度
2015/08/04 职场文书
大学生就业指导课心得体会
2016/01/15 职场文书