前端工程师在开发页面的时候,经常会碰到一个很实际的问题: 在后端接口还没开发完成时,前端怎么办? 通常有两种方案:
- 直接在代码中 mock 相应的数据。这种方案的缺点很明显,会引入无用的代码。
- 请求转发,利用nginx或者本地server(webpack-serve)将本地开会过程中调用的接口转发到nei线上服务。
方案二看似完美,但是在实际使用过程中有配置成本层面的问题:
- 接口变更(新增、删除、修改)都需要更新转发路由表的配置文件
- 接口开始和关闭mock服务,配置比较繁琐,不够直观
- webpack-serve方式代理,在多人协助时git冲突不可避免
基于目前开发阶段前端工程师大多使用chrome调试的现状,将方案二中请求转发的逻辑迁移到浏览器中处理,并提供开启关闭接口mock的交互界面。
插件初始化阶段
- 进入devtools的时候,判断当前域名下面有没有项目
- 没有的话,新建项目
- 有的话遍历当前域名下面的项目
- 获取业务分组和接口
- 判断当前项目下paths的有效状态(是否被删除)和选中状态
- 开启和关闭接口
页面js运行时
- 拦截请求,判断origin !== 'nei.netease.com'并且path命中,两个条件都符合的话做307跳转
-
安装插件
- 插件地址: nei-chrome-devtoos,也可以使用源码安装 https://github.com/amibug/nei-chrome-devtools
-
新建项目(ps: 需要先登录,未登录会打开nei登录页面),输入pid后会先显示该项目下所有的项目分组和接口
- 项目ID指的是项目链接中pid参数对应的值 https://nei.netease.com/project?pid=${pid}
-
业务开发过程中开启和关闭接口mock,日常开发中-"常用接口分组"是使用频率最高的分组,需要注意的地方有2点:
-
demo演示
- 插件数据都存储在localstorage中,清理缓存后部分配置会失效,但是配置相当简单有何所谓呢~