Android-WebView加载网页

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

webview有两个方法:setWebChromeClient 和 setWebClient

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

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

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

使用WebView需要访问网络权限:

<uses-permission android:name="android.permission.INTERNET"/>

1、加载本地/web资源
example.html 存放在assets文件夹内

webView = (WebView) findViewById(R.id.webView);
webView.loadUrl("file:///android_asset/example.html");//加载本地资源
webView.loadUrl("http://baidu.com");//加载web资源

2、在程序内打开网页
创建一个自己的WebViewClient,通过setWebViewClient关联

    webView = (WebView) findViewById(R.id.webView);
    WebSettings settings = webView.getSettings();
    //如果访问的页面中有Javascript,则webview必须设置支持Javascript
    settings.setJavaScriptEnabled(true);
    //WebView加载web资源
    webView.loadUrl("http://baidu.com");
    //覆盖WebView默认使用第三方或系统默认浏览器打开网页的行为,使网页用WebView打开
    webView.setWebViewClient(new WebViewClient(){
        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
            //返回值是true的时候控制去WebView打开,为false调用系统浏览器或第三方浏览器
            view.loadUrl(url);
            return true;
        }
    });

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

    //改写物理按键——返回的逻辑
    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        if(keyCode == KeyEvent.KEYCODE_BACK){
            if(webView.canGoBack()){
                webView.goBack();//返回WebView上一页面
                return true;
              } else {
                finish();//结束当前窗体
                System.exit(0);//退出程序
            }
        }
      return super.onKeyDown(keyCode, event); 
    }

4、判断页面加载过程

webView.setWebChromeClient(new WebChromeClient() {
    @Override
    public void onProgressChanged(WebView view, int newProgress) {
        // TODO Auto-generated method stub
        if (newProgress == 100) {
        // 网页加载完成
        } else {
            // 加载中
        }
    }
});

5、WebView相关设置

    webview = (WebView) findViewById(R.id.webview);  
    WebSettings webSettings = webview.getSettings();  
    //设置WebView属性,能够执行Javascript脚本    
    webSettings.setJavaScriptEnabled(true);    
    //设置可以访问文件  
    webSettings.setAllowFileAccess(true);  
    //设置支持缩放  
    webSettings.setBuiltInZoomControls(true); 
    webSettings.setSupportZoom(true); 
    //优先使用缓存
    webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);
    //不使用缓存
    webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);

    //设置此属性,可任意比例缩放
    webSettings.setUseWideViewPort(true);
    webSettings.setLoadWithOverviewMode(true);

    //支持获取手势焦点
    webview.requestFocusFromTouch();

    //加载需要显示的网页    
    webview.loadUrl("http://www.baidu.com");    
    //设置Web视图    
    webview.setWebViewClient(new webViewClient ()); 

6、通过java代码调用javascript

    WebSettings webSettings = mWebView .getSettings();       
    webSettings.setJavaScriptEnabled(true); 
    mWebView.addJavascriptInterface(new Object() {       
        public void clickOnAndroid() {       
            mHandler.post(new Runnable() {       
                public void run() {       
                    webview.loadUrl("javascript:wave()");       
                }       
            });       
        }       
    }, "demo");

WebSettings 的常用方法介绍

setJavaScriptEnabled(true);  //支持js

setPluginsEnabled(true);  //支持插件 

setUseWideViewPort(false);  //将图片调整到适合webview的大小 

setSupportZoom(true);  //支持缩放 

setDisplayZoomControls(false);//不显示WebView缩放按钮

setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN); //支持内容重新布局  

supportMultipleWindows();  //多窗口 

setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);  //关闭webview中缓存 

setAllowFileAccess(true);  //设置可以访问文件 

setNeedInitialFocus(true); //当webview调用requestFocus时为webview设置节点

webview webSettings.setBuiltInZoomControls(true); //设置支持缩放 

setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口 

setLoadWithOverviewMode(true); // 缩放至屏幕的大小

setLoadsImagesAutomatically(true);  //支持自动加载图片

WebViewClient 的方法全解

doUpdateVisitedHistory(WebView view, String url, boolean isReload)  //(更新历史记录) 

onFormResubmission(WebView view, Message dontResend, Message resend) //(应用程序重新请求网页数据) 

onLoadResource(WebView view, String url) // 在加载页面资源时会调用,每一个资源(比如图片)的加载都会调用一次。 

onPageStarted(WebView view, String url, Bitmap favicon) //这个事件就是开始载入页面调用的,通常我们可以在这设定一个loading的页面,告诉用户程序在等待网络响应。 

onPageFinished(WebView view, String url) //在页面加载结束时调用。同样道理,我们知道一个页面载入完成,于是我们可以关闭loading 条,切换程序动作。 

onReceivedError(WebView view, int errorCode, String description, String failingUrl)// (报告错误信息) 

onReceivedHttpAuthRequest(WebView view, HttpAuthHandler handler, String host,String realm)//(获取返回信息授权请求) 

onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) //重写此方法可以让webview处理https请求。

onScaleChanged(WebView view, float oldScale, float newScale) // (WebView发生改变时调用) 

onUnhandledKeyEvent(WebView view, KeyEvent event) //(Key事件未被加载时调用) 

shouldOverrideKeyEvent(WebView view, KeyEvent event)//重写此方法才能够处理在浏览器中的按键事件。 

shouldOverrideUrlLoading(WebView view, String url) 
//在点击请求的是链接是才会调用,重写此方法返回true表明点击网页里面的链接还是在当前的webview里跳转,不跳到浏览器那边。这个函数我们可以做很多操作,比如我们读取到某些特殊的URL,于是就可以不打开地址,取消这个操作,进行预先定义的其他操作,这对一个程序是非常必要的。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值