如何解决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 相关文章推荐
IE浏览器兼容Firefox的JS脚本的代码
Oct 23 Javascript
JavaScript NaN和Infinity特殊值 [译]
Sep 20 Javascript
jQuery中:reset选择器用法实例
Jan 04 Javascript
JavaScript操作Cookie方法实例分析
May 27 Javascript
跟我学习javascript的prototype,getPrototypeOf和__proto__
Nov 17 Javascript
angular route中使用resolve在uglify压缩后问题解决
Sep 21 Javascript
使用vue.js写一个tab选项卡效果
Mar 25 Javascript
AngularJS 表单验证手机号的实例(非必填)
Nov 12 Javascript
vue数组对象排序的实现代码
Jun 20 Javascript
vue-cli3添加模式配置多环境变量的方法
Jun 05 Javascript
Elasticsearch实现复合查询高亮结果功能
Sep 10 Javascript
vue的项目如何打包上线
Apr 13 Vue.js
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简单的留言板与回复功能具体实现
2014/02/19 PHP
thinkphp使用literal防止模板标签被解析的方法
2014/11/22 PHP
1亿条数据如何分表100张到Mysql数据库中(PHP)
2015/07/29 PHP
Thinkphp5框架简单实现钩子(Hook)行为的方法示例
2019/09/03 PHP
JS 面向对象之神奇的prototype
2011/02/26 Javascript
js URL参数的拼接方法比较
2012/02/15 Javascript
jquery给图片添加鼠标经过时的边框效果
2013/11/12 Javascript
JavaScript判断按钮被点击的方法
2015/12/13 Javascript
jQuery Ajax 加载数据时异步显示加载动画
2016/08/01 Javascript
AngularJS入门教程引导程序
2016/08/18 Javascript
jQuery插件FusionWidgets实现的Bulb图效果示例【附demo源码下载】
2017/03/23 jQuery
浅谈node中的exports与module.exports的关系
2017/08/01 Javascript
Vue.js递归组件构建树形菜单
2017/12/24 Javascript
关于HTTP传输中gzip压缩的秘密探索分析
2018/01/12 Javascript
如何根据业务封装自己的功能组件
2019/04/19 Javascript
深入了解JavaScript 防抖和节流
2019/09/12 Javascript
[01:58]最残酷竞争 2016国际邀请赛中国区预选赛积分循环赛回顾
2016/06/28 DOTA
TensorFlow高效读取数据的方法示例
2018/02/06 Python
python使用for循环计算0-100的整数的和方法
2019/02/01 Python
解决Python Matplotlib绘图数据点位置错乱问题
2020/05/16 Python
使用css3制作登录表单的步骤
2014/04/07 HTML / CSS
巴基斯坦电子产品购物网站:Home Shopping
2017/09/14 全球购物
美津浓巴西官方网站:Mizuno巴西
2019/07/24 全球购物
波兰最大的宠物用品网上商店:FERA.PL
2019/08/11 全球购物
Blue Nile中国官网:全球知名的钻石和珠宝网络零售商
2020/03/22 全球购物
大专毕业生简历的自我评价
2013/10/20 职场文书
早餐连锁店计划书
2014/01/08 职场文书
小摄影师教学反思
2014/04/27 职场文书
创先争优演讲稿
2014/09/15 职场文书
三八妇女节寄语
2015/02/27 职场文书
2016七夕情人节寄语
2015/12/04 职场文书
《7的乘法口诀》教学反思
2016/02/18 职场文书
《失物招领》教学反思
2016/02/20 职场文书
工作简历的自我评价
2019/05/16 职场文书
mysql自增长id用完了该怎么办
2022/02/12 MySQL
UNION CREATIVE《Re:从零开始的异世界生活》雷姆手办
2022/03/20 日漫