Android:webView总结
2010-09-10 01:03:00 来源:WEB开发网我们看addJavascriptInterface(Object obj,String interfaceName)这个方法,该方法将一个java对象绑定到一个javascript对象中,javascript对象名就是 interfaceName(demo),作用域是Global。这样初始化webview后,在webview加载的页面中就可以直接通过 javascript:window.demo访问到绑定的java对象了。来看看在html中是怎样调用的。
1. < html>
2. < mce:script language="javascript">< !--
3.
4. function wave() {
5. document.getElementById("droid").src="http://www.cnmsdn.com/html/201009/android_waving.png";
6. }
7.
8. // -->< /mce:script>
9. < body>
10. < a >
11. < img id="droid" src="http://www.cnmsdn.com/html/201009/android_normal.png" mce_src="http://www.cnmsdn.com/html/201009/android_normal.png"/>< br>
12. Click me!
13. < /a>
14. < /body>
15. < /html>
< html> < mce:script language="javascript">< !-- function wave() { document.getElementById("droid").src="http://www.cnmsdn.com/html/201009/android_waving.png"; } // -->< /mce:script> < body> < a > < img id="droid" src="http://www.cnmsdn.com/html/201009/android_normal.png" mce_src="http://www.cnmsdn.com/html/201009/android_normal.png"/>< br> Click me! < /a> < /body> < /html>
这样在javascript中就可以调用java对象的clickOnAndroid()方法了,同样我们可以在此对象中定义很多方法(比 如发短信,调用联系人列表等手机系统功能。),这里wave()方法是java中调用javascript的例子。
这里还有几个知识点:
1)为了让WebView从apk文件中加载 assets,Android SDK提供了一个schema,前缀为"file:///android_asset/"。WebView遇到这样的schema,就去当前包中的 assets目录中找内容。如上面的"file:///android_asset/demo.html"
2)addJavascriptInterface方法中要绑定的Java对象及方法要运行另外的线程中,不能运行在构造他的线程中,这也是使用 Handler的目的。
更多精彩
赞助商链接