Eruda: 手机网页调试利器 - V2EX
surunzi

Eruda: 手机网页调试利器

  •  
  •   surunzi Oct 31, 2016 10345 views
    This topic created in 3503 days ago, the information mentioned may be changed or developed.

    https://github.com/liriliri/eruda

    距上次发贴已过去半年,最新版本为 v1.1.3 ,期间做了不少改进,经常做 app 内嵌 WebView 开发的小伙伴们可以试下:)

    npm version

    Eruda 是一个专为手机网页前端设计的调试面板,类似 DevTools 的迷你版,其主要功能包括:捕获 console 日志、检查元素状态、显示性能指标、捕获 XHR 请求、显示本地存储和 Cookie 信息、浏览器特性检测等等。

    功能清单

    Eruda

    1. 按钮拖拽,面板透明度大小设置。

    2. Console 面板:捕获 Console 日志,支持 log 、 error 、 info 、 warn 、 dir 、 time/timeEnd 、 clear 、 count 、 assert 、 table ;支持占位符,包括%c 自定义样式输出;支持按日志类型及正则表达式过滤;支持快捷命令加载 underscore 、 jQuery 库;支持 Javascript 脚本执行。

    3. Elements 面板:查看标签内容及属性;查看应用在 Dom 上的样式;支持页面元素高亮;支持屏幕直接点击选取;查看 Dom 上绑定的各类事件。

    4. Network 面板:图表显示页面加载速度;查看页面各资源请求时间( Android );捕获 XHR 请求,查看发送数据、返回头、返回内容等信息。

    5. Resources 面板:查看并清除 localStorage 、 sessionStorage 及 cookie ;查看页面加载脚本及样式文件;查看页面加载图片。

    6. Sources 面板:查看页面源码;格式化 html , css , js 代码及 json 数据。

    7. Info 面板:输出 URL 及 User Agent ;支持自定义输出内容。

    8. Snippets 面板:页面元素添加边框;加时间戳刷新页面;支持自定义代码片段。

    9. Features 面板:浏览器常用特性检测;提供 Can I use , Html5Test 快捷访问。

    快速上手

    通过 npm 安装:

    npm install eruda --save 

    在页面中加载脚本:

    <script src="node_modules/eruda/eruda.min.js"></script> <script>eruda.init();</script> 

    Js 文件对于移动端来说略重( gzip 后大概 80kb )。建议通过 url 参数来控制是否加载调试器,比如:

    ;(function () { var src = 'node_modules/eruda/eruda.min.js'; if (!/eruda=true/.test(window.location) && localStorage.getItem(active-eruda') != 'true') return; document.write('<scr' + 'ipt src="' + src + '"></scr' + 'ipt>'); document.write('<scr' + 'ipt>eruda.init();</scr' + 'ipt>'); })(); 

    初始化时可以传入配置:

    • container: 用于插件初始化的 Dom 元素,如果不设置,默认创建 div 作为容器直接置于 html 根结点下面。
    • tool :指定要初始化哪些面板,默认加载所有。
    var el = document.createElement('div'); document.body.appendChild(el); eruda.init({ container: el, tool: ['console', 'elements'] }); 

    该工具支持自行编写插件,可参考eruda-fps

    Demo

    Demo

    请扫描二维码或在手机上直接访问:http://liriliri.github.io/eruda/

    如果想在其它页面尝试,请在浏览器地址栏上输入以下代码。

    Javascript:(function () { var script = document.createElement('script'); script.src="http://www.v2ex.com//liriliri.github.io/eruda/eruda.min.js"; document.body.appendChild(script); script.Onload= function () { eruda.init() } })(); 
    2 replies    2016-11-01 17:20:11 +08:00
    jas0ndyq
        1
    jas0ndyq  
       Nov 1, 2016 via iPhone
    感谢分享
    begoingtodo
        2
    begoingtodo  
       Nov 1, 2016
    赞一个!
    About     Help     Advertise     Blog     API     FAQ     Solana     5581 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 73ms UTC 06:32 PVG 14:32 LAX 23:32 JFK 02:32
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86