android webview

Android WebView 使用详解

大部分内容为网上整理其它高人的帖子,现只作整理,用于查看:

在Android手机中内置了一款高性能webkit内核浏览器,在SDK中封装为一个叫做WebView组件。

什么是webkit


WebKit是Mac OS X v10.3及以上版本所包含的软件框架(对v10.2.7及以上版本也可通过软件更新获取)。 同时,WebKit也是Mac OS X的Safari网页浏览器的基础。WebKit是一个开源项目,主要由KDE的KHTML修改而来并且包含了一些来自苹果公司的一些组件。


传统上,WebKit包含一个网页引擎WebCore和一个脚本引擎JavaScriptCore,它们分别对应的是KDE的KHTML和KJS。不过, 随着JavaScript引擎的独立性越来越强,现在WebKit和WebCore已经基本上混用不分(例如Google Chrome和Maxthon 3采用V8引擎,却仍然宣称自己是WebKit内核)。


这里我们初步体验一下在android是使用webview浏览网页,在SDK的Dev Guide中有一个WebView的简单例子 。


在开发过程中应该注意几点:

    1.AndroidManifest.xml中必须使用许可"android.permission.INTERNET",否则会出Web page not available错误。
    2.如果访问的页面中有Javascript,则webview必须设置支持Javascript。
        webview.getSettings().setJavaScriptEnabled(true); 
    3.如果页面中链接,如果希望点击链接继续在当前browser中响应,而不是新开Android的系统browser中响应该链接,必须覆盖 webview的WebViewClient对象。

  1. mWebView.setWebViewClient(new WebViewClient(){      
  2.                    publicboolean shouldOverrideUrlLoading(WebView view, String url) {      
  3.                         view.loadUrl(url);      
  4.                        returntrue;      
  5.                     }      
  6.         });  

4.如果不做任何处理,浏览网页,点击系统“Back”键,整个Browser会调用finish()而结束自身,如果希望浏览的网 页回退而不是推出浏览器,需要在当前Activity中处理并消费掉该Back事件。

  1. publicboolean onKeyDown(int keyCode, KeyEvent event) {      
  2.         if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) {      
  3.             mWebView.goBack();      
  4.                   returntrue;      
  5.         }      
  6.         returnsuper.onKeyDown(keyCode, event);      
  7.     }    

下一步让我们来了解一下android中webview是如何支持javascripte自定义对象的,在w3c标准中js有 window,history,document等标准对象,同样我们可以在开发浏览器时自己定义我们的对象调用手机系统功能来处理,这样使用js就可以 为所欲为了。

  看一个实例:

  1. publicclass WebViewDemoextends Activity {       
  2.     private WebView mWebView;      
  3.     private Handler mHandler =new Handler();      
  4.       
  5.     publicvoid onCreate(Bundle icicle) {      
  6.         super.onCreate(icicle);      
  7.         setContentView(R.layout.webviewdemo);      
  8.         mWebView = (WebView) findViewById(R.id.webview);      
  9.         WebSettings webSettings = mWebView.getSettings();      
  10.         webSettings.setJavaScriptEnabled(true);      
  11.         mWebView.addJavascriptInterface(new Object() {      
  12.             publicvoid clickOnAndroid() {      
  13.                 mHandler.post(new Runnable() {      
  14.                    publicvoid run() {      
  15.                         mWebView.loadUrl("javascript:wave()");      
  16.                     }      
  17.                 });      
  18.             }      
  19.         }, "demo");      
  20.         mWebView.loadUrl("file:///android_asset/demo.html");      
  21.     }      
  22. }  

我们看addJavascriptInterface(Object obj,String interfaceName)这个方法,该方法将一个java对象绑定到一个javascript对象中,javascript对象名就是 interfaceName(demo),作用域是Global。这样初始化webview后,在webview加载的页面中就可以直接通过 javascript:window.demo访问到绑定的java对象了。来看看在html中是怎样调用的。

  1. <html>      
  2.         <mce:scriptlanguage="javascript"><!--    
  3.       
  4.                 function wave() {      
  5.                     document.getElementById("droid").src="android_waving.png";      
  6.                 }      
  7.             
  8. // --></mce:script>      
  9.         <body>      
  10.             <aonClick="window.demo.clickOnAndroid()">      
  11.                                <imgid="droid"src="android_normal.png"mce_src="android_normal.png"/><br>      
  12.                                 Click me!      
  13.             </a>      
  14.         </body>      
  15. </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的目的。

 

http://developer.android.com/reference/android/webkit/WebView.html

http://developer.51cto.com/art/201008/216488.htm

http://blog.youkuaiyun.com/chenshijun0101/article/details/7045394

http://www.eoeandroid.com/thread-237589-1-1.html

http://www.360doc.com/content/13/0522/20/110467_287355850.shtml

http://www.jb51.net/article/32597.htm

http://www.ibm.com/developerworks/cn/web/1011_guozb_html5off/: html5离线应用

http://bbs.phonegapcn.com/forum.php?mod=viewthread&tid=387:phonegap:可操作本地device, 用web应用的方式封装本地接口。

http://mobile.51cto.com/others-308545.htm: phonegap

http://blog.youkuaiyun.com/yangdeli888/article/details/7477932

http://wenku.baidu.com/view/dedb8bb269dc5022aaea0026.html: phongap

http://www.2cto.com/kf/201207/143975.html: phonegap

http://blog.youkuaiyun.com/liu01983zm/article/details/6331753

http://wenku.baidu.com/view/273c787602768e9951e73833.html: phonegap使用,就当一般的网页开发。  java /js/html/css/webview结合。

http://wenku.baidu.com/view/b6fe35699b6648d7c1c7463e.html:讲的更多一些。

 

 

http://www.cnblogs.com/mengdd/archive/2013/03/01/2938295.html: webview使用

 

http://blog.youkuaiyun.com/feifei454498130/article/details/6524183:讲得好。

 http://zhidao.baidu.com/question/424887069.html: java调用js

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值