V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
surunzi
V2EX  ›  JavaScript

Eruda: 手机网页调试利器

  •  
  •   surunzi · 2016-10-31 20:33:36 +08:00 · 9612 次点击
    这是一个创建于 2949 天前的主题,其中的信息可能已经有所发展或是发生改变。

    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="//liriliri.github.io/eruda/eruda.min.js"; document.body.appendChild(script); script.onload = function () { eruda.init() } })();
    
    2 条回复    2016-11-01 17:20:11 +08:00
    jas0ndyq
        1
    jas0ndyq  
       2016-11-01 00:30:40 +08:00 via iPhone
    感谢分享
    begoingtodo
        2
    begoingtodo  
       2016-11-01 17:20:11 +08:00
    赞一个!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3100 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 14:28 · PVG 22:28 · LAX 06:28 · JFK 09:28
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.