最近在学习Android WebView的使用,期间遇到一些Bug,总结在此。
1.JS调用JAVA代码时报错,log如下:
10-27 07:30:23.411: I/chromium(5437): [INFO:CONSOLE(49)] "Uncaught TypeError: Object [object Object] has no method 'initST'", source: file:///android_asset/www/index.html (49)
这个问题是因为use-sdk中配置android:targetSdkVersion大于17时,js不能调用到java代码。
解决办法:
(1).修改android:targetSdkVersion="10",小于17就行,这个只能为一时的解决方案,
(2).android:targetSdkVersion大于17时,需要在js调用的java代码上方加上JavascriptInterface的注解(即@JavascriptInterface),同时,在混淆代码时,注意不要混淆JavascriptInterface的注解,否则也会出现js不能调用java代码的情况发生。(-keep attributes *Annotation*)
-keepclassmembers class cn.xx.xx.Activity$AppAndroid {
public *;
}
-keepattributes *Annotation*
-keepattributes *JavascriptInterface*
final class DemoJavaScriptInterface {
DemoJavaScriptInterface() {
}
@JavascriptInterface
public void initST(final String str) {
mHandler.post(new Runnable() {
public void run() {
}
});
}
}
10-27 07:52:04.601: I/chromium(5638): [INFO:CONSOLE(1)] "Uncaught ReferenceError: wave is not defined", source: file:///android_asset/www/index.html (1)
10-27 07:52:04.621: I/chromium(5638): [INFO:CONSOLE(1)] "Uncaught ReferenceError: test is not defined", source: file:///android_asset/www/index.html (1)