如何通过日志来调试Web App
在Android浏览器中使用控制台API
如果我们在网页的JavaScript脚本代码中调用了window.console对象的方法比如log()方法向控制台输出日志信息,我们就会在Android的logcat中看到该日志信息。比如,下面的代码:
console.log("Hello World");
在logcat中就会显示下面的信息:
Console: Hello World http://www.example.com/hello.html :82
上述信息的格式在不同的Android系统中可能会有差别。在Android 2.1及以上版本中,Android浏览器的控制台信息的输出标签为“browser”,而在Android 1.6及以下版本中,标签则为“WebCore”。Android的WebKit引擎主要支持以下JavaScript控制台API:
console.log(String)
console.info(String)
console.warn(String)
console.error(String)
在WebView中使用控制台API
上面列出的控制台API也适用于WebView。在Android 2.1(API level 7)及以上版本中,我们需要提供一个WebChromeClient类的对象并覆写它的onConsoleMessage()方法才能使控制台的输出信息出现在logcat中。然后通过WebView的setWebChromeClient()方法把该对象传递给WebView。下面为一个API level 7中的示例:
WebView myWebView = (WebView) findViewById(R.id.webview);
myWebView.setWebChromeClient(new WebChromeClient() {
public void onConsoleMessage(String message, int lineNumber, String sourceID) {
Log.d("MyApplication", message + " -- From line "
+ lineNumber + " of "
+ sourceID);
}
});
在API level 8及以上版本中,需要这样来写:
WebView myWebView = (WebView) findViewById(R.id.webview);
myWebView.setWebChromeClient(new WebChromeClient() {
public boolean onConsoleMessage(ConsoleMessage cm) {
Log.d("MyApplication", cm.message() + " -- From line "
+ cm.lineNumber() + " of "
+ cm.sourceId() );
return true;
}
});
上面例子中的ConsoleMessage对象还包括了一个MessageLevel对象,可以获取到控制台输出的类型信息,这是通过调用MessageLevel对象的messageLevel()方法来获取到的,然后在Android代码中使用相应的Log类的方法或做其他的处理。当我们在网页中使用JavaScript脚本向控制台输出信息时,根据不同的版本Android系统会调用onConsoleMessage(String, int, String)或onConsoleMessage(ConsoleMessage)方法使页面的错误信息出现在logcat中。比如,对于下面的代码:
console.log("Hello World");
在logcat中的输出可能为:
Hello World -- From line 82 of http://www.example.com/hello.html
更多相关文章
- Android(安卓)Volley入门到精通:初识Volley的基本用法(示例,出错
- android面试题(一)
- Android异步2:深入详解 Handler+Looper+MessageQueue
- Android获取网易云音乐歌曲详细信息
- android使用sax解析xml
- Android(安卓)GPS 定位的实现(2-1) 使用Google地图
- 详解Serializable
- Android之log
- 详解Android中获取SD卡和内存的空间信息