网易首页 > 网易号 > 正文 申请入驻

Mdebug:基于React开发的移动web调试工具

0
分享至

作者:thinkchen,腾讯 PCG 高级前端开发工程师

是腾讯新闻 TNTWEB 团队推出的基于React开发的新的web调试工具, 沉淀自腾讯新闻微信手 q 双插件多年的移动 web 开发实践中。相比 vconsole, eruda 等调试工具, 使用现代框架进行编写。整合 network 监控能力,提供了更丰富的调试能力和 api, 拥有更强大的网络捕获能力,接入和使用简单。本文将从背景, 架构,功能, 实现原理, 未来扩展点等角度全面介绍这款工具。

一.背景

调试一直是移动 web 开发的疼点,业界也在调试工具上不断寻找更好的解决方案。从真机联调js 模拟Nodejs 代理,代理软件等方面提出移动 web 调试解决方案。是一款通过 js 模拟来实现移动 web 调试的轻量化工 具,无需依赖任何插件,使用简单,功能强大。

git 地址:

快速体验:

二、功能介绍

mdebug 提供了系统,日志,网络,元素,存储,代理,性能七大实用功能。下面我们逐一介绍这些功能:

1.系统

系统功能提供了当前访问地址,UA,视窗大小,用户标示等信息,并支持点击复制,可以让你快速了解当前系统情况。
2.元素
呈现了当前页面的 dom 元素,可以快速了解当前页面的 dom 元素情况,支持展开和折叠,体验接近 chrome devtools elements。
3. 日志
支持多种日志展现,支持日志分类,全局过滤,日志导出,执行 js 命令,支持长日志折叠展开,提升大日志量展示性能等功能。
4.网络
支持多种网络请求查看,包括静态资源,接口,websocket 请求等,并支持模糊查找。
5.存储和 Cookie
支持多种存储展现,支持增删存储,支持模糊查找,支持长日志折叠展开,提升大日志量展示性能等功能。
6. 前端代理 proxy
简单版的本地 host,支持通过面板快速修改域名代理,将页面请求转发到另外一个域名
7.性能 performance
参考业界性能监控常用指标,输出页面当前性能情况

三、快速使用 1. ES6import mdebug from 'mdebug';
mdebug.init();
2. CDN(function() {
var scp = document.createElement('script');
// 加载最新的mdebug版本
scp.src = 'https://unpkg.com/mdebug@latest/dist/index.js';
scp.async = true;
scp.charset = 'utf-8';
// 加载成功并初始化
scp.onload = function() {
mdebug.init();
// 加载状态切换回调
scp.onreadystate = function() {};
// 加载失败回调
scp.onerror = function() {};
document.getElementsByTagName('head')[0].appendChild(scp);
四. API 介绍 1. initmdebug.init({
containerId: '' // mdebug挂载容器id, 如果传空, 内部会自动生成一个不重复的id,
plugins: [], // 传入mdebug插件
hideToolbar: [], // 传入需要隐藏的tab id
2. addPluginmdebug.addPlugin({
id: '', // tab id
name: '', // tab对应的中文title,
enName: '', // tab对应的英文title
component: () => {}, // tab对应的react组件
3. removePlugin// 支持移除的panel对应的id
System => system;
Elements => elements;
Console => console
Application => application
NetWork => network
Performance => performance
Settings => settings
mdebug.removePlugin([]);
4. exportLog
@returned {
type: '' // 日志类型
source: [], // 原始日志
@params type
// type等于log, 返回所有的console日志
// type等于net, 返回所有的net日志
mdebug.exportLog(type);

5. onmdebug.on(eventName, callback);
6. emitmdebug.emit(eventName, data);
五、事件列表

六.业界主流调试工具介绍 1. js 模拟

  • erudahttps://github.com/liriliri/eruda/blob/master/doc/README_CN.md

  • vconsolehttps://blog.csdn.net/yihanzhi/article/details/105728049 https://liuxianyu.cn/article/mobile-vConsole.html

2.抓包工具

  • Fiddlerhttps://www.cnblogs.com/yyhh/p/5140852.html



  • Charleshttps://www.cnblogs.com/peng-lan/p/11242954.html https://www.cnblogs.com/linyfeng/p/9496126.html



  • Tcpdumphttps://juejin.cn/post/6844904084168769549



  • USBhttps://aotu.io/notes/2017/02/24/Mobile-debug/index.html


3. Nodejs 代理工具
  • whistlehttps://segmentfault.com/a/1190000014891582

  • LivePoolhttps://www.freebuf.com/sectool/73408.html

  • AnyProxyhttps://jingyan.baidu.com/article/948f5924d0c9a3d80ff5f983.html

七、业界方案对比

和业界 js 模拟调试工具相比,mdebug 在扩展性用户体验上做了更多思考和探索。

mdebug 基于 react 框架编写, 充分利用组件化思想,简化实现逻辑。可以和现有 react 组件充分结合提升扩展性。并通过事件机制来降低 mdebug 和外部的业务逻辑代码通信负担。

通过 hook console api 来将 console 输出的日志,传输到 mdebug 中进行格式化展现。并支持对日志进行检索,导出等功能

2. Hook Fetch Ajax

mdebug 在底层拦截网络请求,将网络请求相关信息,存储在内存队列中,并派发相关事件给 mdebug 进行展现。同时支持对网络请求日志进行全局检索,导出等

3. Performance API

通过 performance api 我们能够获取到浏览器页面加载性能,静态资源加载等情况。

(1) 页面性能

mdebug 使用 window.performance.timing 来获取页面性能加载数据,并参考业界常用性能指标计算方式,为业务提供简单直观的性能数据。

(2) 静态资源加载

通过 performance.getEntries 来获取页面静态资源加载情况,并通过事件机制通知到 mdebug network 面板。

相关源码

4.使用 redux 来进行状态管理 5. 调用原生存储 api 来获取,设置,删除存储 6. 除了 redux 状态管理外,通过 eventbus 事件机制来进行日志,网络数据的派发通知, 以及 mdebug 和外部业务逻辑代码的通信。 十、未来拓展点

mdebug 作为移动 web 调试工具的一个新的探索,未来可以结合业务实践沉淀更多的功能。通过插件的机制来供业务自由组合使用。另外我们也在探索多前端框架支持,插件编写上可以支持 vue,react,原生 js 等。另外作为一个 react 入门学习项目,也是一个很好的实践项目。

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
新血压标准已公布,高血压不再是120/80mmHg,愿你的血压在它之下

新血压标准已公布,高血压不再是120/80mmHg,愿你的血压在它之下

熊猫医学社
2026-02-06 11:35:03
17岁高中生肝癌晚期,从不喝酒,医生询问后明白:常拿1物当夜宵

17岁高中生肝癌晚期,从不喝酒,医生询问后明白:常拿1物当夜宵

九哥聊军事
2026-02-08 22:40:30
中国正加速抛售美债,美专家:中国用了新抛售方式,完全无法干预

中国正加速抛售美债,美专家:中国用了新抛售方式,完全无法干预

似水流年忘我
2026-01-29 01:24:08
22℃!冷空气又来!江苏天气最新预测!

22℃!冷空气又来!江苏天气最新预测!

微淮安
2026-02-17 19:21:30
这5种茶叶已被列入“伤肝名单”,很多人天天喝,建议转告家里人

这5种茶叶已被列入“伤肝名单”,很多人天天喝,建议转告家里人

揽星河的笔记
2025-11-06 16:12:21
哪些抵债方式让你出乎意料?网友:她没有再提,临走悄悄给了两万

哪些抵债方式让你出乎意料?网友:她没有再提,临走悄悄给了两万

夜深爱杂谈
2026-01-23 20:20:15
全面取消!中国反制手段升级!高市慌了,踩红线让日本已无力承受

全面取消!中国反制手段升级!高市慌了,踩红线让日本已无力承受

趣生活
2026-02-17 16:43:20
李阳公开力挺释永信:中国人不要仇富,他是少林寺的重要功臣!

李阳公开力挺释永信:中国人不要仇富,他是少林寺的重要功臣!

陌上桃花开的
2026-02-14 16:21:21
新任金华市政协党组副书记,已明确!

新任金华市政协党组副书记,已明确!

浙中在线
2026-02-17 20:34:29
一年营业一次,这一次,57岁的王菲以奇怪的方式出圈

一年营业一次,这一次,57岁的王菲以奇怪的方式出圈

妙知
2026-02-17 08:28:01
委内瑞拉和伊朗这一手“反水”,直接给中国上一堂最昂贵的战略课

委内瑞拉和伊朗这一手“反水”,直接给中国上一堂最昂贵的战略课

南权先生
2026-01-16 16:22:00
继续创造历史!中国男团0.09秒险胜夺速滑追逐铜牌,太不容易了!

继续创造历史!中国男团0.09秒险胜夺速滑追逐铜牌,太不容易了!

篮球资讯达人
2026-02-17 23:32:16
官宣!76人捡漏成功,刚被裁却拿220万,这人生赢家因祸得福

官宣!76人捡漏成功,刚被裁却拿220万,这人生赢家因祸得福

布斯基
2026-02-17 23:00:08
女子空中技巧预赛因强降雪持续延迟,比赛20:45之前不会开始

女子空中技巧预赛因强降雪持续延迟,比赛20:45之前不会开始

懂球帝
2026-02-17 19:53:06
春晚歌舞类收视榜出炉!凤凰传奇第二,成龙第四,第一名都没想到

春晚歌舞类收视榜出炉!凤凰传奇第二,成龙第四,第一名都没想到

小徐讲八卦
2026-02-17 11:47:33
当年举报毕福剑的那位告密者竟然变成这样了!谁能想到啊?

当年举报毕福剑的那位告密者竟然变成这样了!谁能想到啊?

霹雳炮
2026-02-06 13:48:54
珍宝岛冲突后中国过度战备后遗症

珍宝岛冲突后中国过度战备后遗症

河山历史
2025-12-25 11:27:27
戴安娜秘密录音曝光:和查尔斯一周三次夫妻生活,他却想当卡米拉卫生棉

戴安娜秘密录音曝光:和查尔斯一周三次夫妻生活,他却想当卡米拉卫生棉

小鱼爱鱼乐
2026-02-17 07:05:58
别再用现金行贿受贿了!大数据一查就现形,全程 “裸奔” 藏不住

别再用现金行贿受贿了!大数据一查就现形,全程 “裸奔” 藏不住

复转这些年
2026-02-09 23:45:54
全球资产深夜大跌,美股半导体股下挫,白银失守72美元,比特币跌破6.7万美元

全球资产深夜大跌,美股半导体股下挫,白银失守72美元,比特币跌破6.7万美元

21世纪经济报道
2026-02-17 23:22:08
2026-02-18 00:20:49
腾讯技术工程
腾讯技术工程
不止于技术
1363文章数 600关注度
往期回顾 全部

科技要闻

春晚这些机器人是怎样做到的?

头条要闻

加州州长纽森炮轰特朗普:把美国未来卖给中国

头条要闻

加州州长纽森炮轰特朗普:把美国未来卖给中国

体育要闻

谷爱凌:'不小心"拿到了银牌 祝大家马年大吉

娱乐要闻

春节档电影首波口碑出炉!

财经要闻

大年初一,这三件事很不寻常

汽车要闻

问界M6更多信息:乾崑智驾ADS4.0+鸿蒙座舱5.0

态度原创

时尚
数码
手机
公开课
军事航空

今年春天最流行的4组配色,过年穿时髦又高级!

数码要闻

消息称AMD首款机架级AI系统Helios大规模量产延至2027年

手机要闻

三星Galaxy S26 Ultra手机防窥屏幕设置界面曝光

公开课

李玫瑾:为什么性格比能力更重要?

军事要闻

美国国务卿鲁比奥发表农历新年祝福

无障碍浏览 进入关怀版