还不是为了工作嘛Ios@IONIC

webview

2015-05-31  本文已影响571人  Ten_Minutes

WebView可以使得网页轻松的内嵌到app里,还可以直接跟js相互调用。

webview有两个方法:setWebChromeClient 和 setWebClient

setWebClient:主要处理解析,渲染网页等浏览器做的事情

setWebChromeClient:辅助WebView处理Javascript的对话框,网站图标,网站title,加载进度等

WebViewClient就是帮助WebView处理各种通知、请求事件的。

在AndroidManifest.xml设置访问网络权限:

控件:

android:layout_width="match_parent"

android:layout_height="match_parent"

android:id="@+id/webView"

/>

用途一:加载本地/Web资源

example.html 存放在assets文件夹内

调用WebView的loadUrl()方法,

加载本地资源

webView =(WebView) findViewById(R.id.webView);

webView.loadUrl("file:///android_asset/example.html");

加载web资源:

webView =(WebView) findViewById(R.id.webView);

webView.loadUrl("http://baidu.com");

用途二:在程序内打开网页

创建一个自己的WebViewClient,通过setWebViewClient关联

packagecom.example.testopen;importandroid.app.Activity;importandroid.os.Bundle;importandroid.webkit.WebView;importandroid.webkit.WebViewClient;publicclassMainActivityextendsActivity {privateWebView webView;

@OverrideprotectedvoidonCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);

setContentView(R.layout.test);

init();

}privatevoidinit(){

webView=(WebView) findViewById(R.id.webView);//WebView加载web资源webView.loadUrl("http://baidu.com");//覆盖WebView默认使用第三方或系统默认浏览器打开网页的行为,使网页用WebView打开,也可以在此处拦截、屏蔽url

webView.setWebViewClient(newWebViewClient(){

@OverridepublicbooleanshouldOverrideUrlLoading(WebView view, String url) {//TODO Auto-generated method stub//返回值是true的时候控制去WebView打开,为false调用系统浏览器或第三方浏览器view.loadUrl(url);returntrue;

}

});

}

}

用途三:

如果访问的页面中有Javascript,则webview必须设置支持Javascript

//启用支持javascriptWebSettings settings =webView.getSettings();

settings.setJavaScriptEnabled(true);

用途四:

如果希望浏览的网页后退而不是退出浏览器,需要WebView覆盖URL加载,让它自动生成历史访问记录,那样就可以通过前进或后退访问已访问过的站点。

//改写物理按键——返回的逻辑@OverridepublicbooleanonKeyDown(intkeyCode, KeyEvent event) {//TODO Auto-generated method stubif(keyCode==KeyEvent.KEYCODE_BACK)

{if(webView.canGoBack())

{

webView.goBack();//返回上一页面returntrue;

}else{

System.exit(0);//退出程序}

}returnsuper.onKeyDown(keyCode, event);

}

用途五:判断页面加载过程

webView.setWebChromeClient(newWebChromeClient() {

@OverridepublicvoidonProgressChanged(WebView view,intnewProgress) {//TODO Auto-generated method stubif(newProgress == 100) {//网页加载完成}else{//加载中}

}

});

用途六:缓存的使用

优先使用缓存

webView.getSettings().setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);

不使用缓存:

webView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);

上一篇下一篇

猜你喜欢

热点阅读