文档内容

在AndroidBrowser中使用控制台API

在WebView中使用控制台API

参考

调试

如果你是在为Android开发web应用,那么,你可以使用控制台(console)的JavaScriptAPI(theconsoleJavaScriptAPIs)来调试你的Javascript代码并将信息输出到logcat。如果你对使用Firebug或WebInspector调试web页面比较熟悉,那么,你对使用console(比如console.log())也应该比较熟悉了。Android的Webkit框架支持大多数同样的API,因此在Android的浏览器中或者WebView中调试的时候,你可以接收来自于web页面的logs。

在AndroidBrowser中使用控制台API

Logcat

Logcat是一个工具,用来转储(dump)系统信息日志。这些信息包括设备抛出错误时的堆栈路径,以及你的应用写下的日志信息和使用JavaScriptconsoleAPI写下的日志信息。

要运行logcat并查看信息,从你的AndroidSDKtools/目录执行adblogcat,或者从DDMS选择Device>Runlogcat。当使用ADTpluginforEclipse时,你同样可以通过打开Logcatview来查看logcat信息,打开途径是Window>ShowView>Other>Android>Logcat.。

在Debugging你可以获取更多关于<codelogcat<code=”">.</codelogcat<>的信息。

当你调用一个console函数(在DOM的window.console对象中),输出会出现在logcat中。例如:如果你的web页面执行了下面的Javascript:

console.log("HelloWorld");

那么logcat信息看起来就是类似于下面的样子:

Console:HelloWorldhttp://www.example.com/hello.html:82

在各个信息的格式根据Android版本的不同可能看起来会有不同。在Android2.1及更高,来自于AndroidBrowser的console信息会标记为”browser”。在Android1.6及更低版本,AndroidBrowser信息则是标记为”WebCore”。

Android的WebKit并没有实现在桌面版浏览器中所实现的所有consoleAPI。但是,你可以使用下面的基本的文本日志函数(textloggingfunction):

console.log(String)

console.info(String)

console.warn(String)

console.error(String)

其他一些console函数不产生错误,但是它的行为与你在其他web浏览器中预期的行为可能不一样。

在WebView中使用控制台API

如果你在应用中实现了一个定制的WebView,那么,当你在WebView中调试你的web页面的时候,所有相同的consoleAPI也是被支持的。在Android1.6及更低版本,console信息是自动发送给logcat的,并加上了”WebCore”日志标签。如果你是为Android2.1(APILevel7)及更高版本开发,那么就必须提供一个实现了onConsoleMessage()回调方法的WebChromeClient,以便让console信息显示在logcat中。

另外,在APILevel7中引入的onConsoleMessage(String,int,String)方法已经弃用了,而在APILevel8中使用的是onConsoleMessage(ConsoleMessage)。

无论你是在为Android2.1(APILevel7)或Android2.2(APILevel8或更高)开发,你都需要实现WebChromeClient并覆盖onConsoleMessage()回调方法。然后,使用setWebChromeClient()将WebChromeClient应用到你的WebView中。

如果是使用APILevel7,那么是使用onConsoleMessage(String,int,String)的代码看起来可能是下面这个样子:

 
  1. WebViewmyWebView=(WebView)findViewById(R.id.webview);
  2. myWebView.setWebChromeClient(newWebChromeClient(){
  3. publicvoidonConsoleMessage(Stringmessage,intlineNumber,StringsourceID){
  4. Log.d("MyApplication",message+"--Fromline"
  5. +lineNumber+"of"
  6. +sourceID);
  7. }
  8. });

如果是使用APILevel8或更高版本,那么你使用onConsoleMessage(ConsoleMessage)代码看起来可能是下面的样子:

 
  1. WebViewmyWebView=(WebView)findViewById(R.id.webview);
  2. myWebView.setWebChromeClient(newWebChromeClient(){
  3. publicbooleanonConsoleMessage(ConsoleMessagecm){
  4. Log.d("MyApplication",cm.message()+"--Fromline"
  5. +cm.lineNumber()+"of"
  6. +cm.sourceId());
  7. returntrue;
  8. }
  9. });

ConsoleMessage还包括MessageLevel来指示出发送的console信息的类型。你可以通过messageLevel()来查询信息层次(messagelevel),以便确定信息重要性,然后再使用合适的Log方法或采用其他合适的行动。

无论你是使用onConsoleMessage(String,int,String)还是onConsoleMessage(ConsoleMessage),当你在web页面中执行一个console方法时,Android会调用合适的onConsoleMessage()方法,以便你能报告错误。例如,采用上面的示例代码,一个logcat信息打印出来可能是下面这个样子的:

HelloWorld--Fromline82ofhttp://www.example.com/hello.html

更多相关文章

  1. Android(安卓)MediaScannerConnection,Android(安卓)MediaScanner
  2. Android(安卓)8.1.0 SystemUI 修改之 - 系统锁屏状态下点击用户
  3. Android(安卓)5.1 启动有线网卡并为其分配静态IP地址
  4. Android注入事件的三种方法比较
  5. Android(安卓)JNI/NDK开发之基本姿势
  6. Android(安卓)实现ListView异步加载图片
  7. android得到已安装和未安装apk的信息
  8. Android(安卓)Robotium小结
  9. [ZZ][Android]使用bindService启动服务

随机推荐

  1. 最新消息:Android 4.0新增功能
  2. Android绘制基础及手写绘制实例
  3. android之后台线程(UI与线程交互)
  4. 3g android4 移植 飞思卡尔i.MX 6Quad An
  5. Looper中的消息队列处理机制
  6. 实训心得___刘晓刚
  7. AndroidAPP开发者注意了,安卓开发将迎来
  8. android中关于AsyncTask的学习
  9. 【Android教程】Android用户系统管理
  10. 基于xml类型的压缩数据流的android获取天