继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

【Android】移动端WebView的使用(一)初体验

吃鸡游戏
关注TA
已关注
手记 497
粉丝 55
获赞 339

[每天认真洗脸,多读书,按时睡,少食多餐。变得温柔,大度,继续善良,保持爱心。不在人前矫情,四处诉说以求宽慰,而是学会一个人静静面对,自己把道理想通。这样的你,单身也所谓啊,你在那么虔诚地做更好的自己,一定会遇到最好的,而那个人也一定值得你所有等待。]

每天认真洗脸,多读书,按时睡,少食多餐。变得温柔,大度,继续善良,保持爱心。不在人前矫情,四处诉说以求宽慰,而是学会一个人静静面对,自己把道理想通。这样的你,单身也所谓啊,你在那么虔诚地做更好的自己,一定会遇到最好的,而那个人也一定值得你所有等待。

在WebView没有出现之前,如果要访问一个网页只能通过打开手机内的浏览器,通过浏览器来加载网页,但是打开浏览器的同时,也脱离了当前的应用软件,这样就大大的降低了网页与应用软件的交互。随着Android SDK的不断升级,官方提供一个WebView控件,专门用于加载网页并实现交互。那么到底WebView是什么?又该如何使用呢?

什么是WebView?

简单来说WebView是移动端用于加载Web页面的控件。

怎么使用WebView?

1、移动端加载网页方式

A、通过打开浏览器访问网页

String weburl ="http://www.baidu.com/";
Uri uri = Uri.parse(weburl);// weburl网址Intent intent = new Intent(Intent.ACTION_VIEW, uri);
startActivity(intent);

B、通过WebView打开本地网页

WebView.loadUrl("file:///android_asset/baidu.html");

注意1:本地文件放在assets文件中,assets文件是main的子文件,与res文件同级。
注意2:设置WebView支持加载本地文件。

WebSettings webSettings = webView.getSettings();// 允许加载Assets和resources文件webSettings.setAllowFileAccess(true);

[本地baidu.html代码]
本地baidu.html代码

C、通过WebView加载网址

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

加载网址,需要在清单文件中加上网络请求权限

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

当WebView加载失败时,可以使用webView.reload();来重新加载。
注意:当加载完网页之后,如果发现网页无法点击,这很可能是WebView没有获取焦点。

webView.requestFocus();// 使页面获取焦点,防止点击无响应

2、WebView基本属性设置

WebView提供很多属性,需要通过WebSettings来进行设置,下面是对一些常用属性进行设置。

// 设置WebView相关属性WebSettings webSettings = webView.getSettings();// 是否缓存表单数据webSettings.setSaveFormData(false);// 设置WebView 可以加载更多格式页面webSettings.setLoadWithOverviewMode(true);// 设置WebView使用广泛的视窗webSettings.setUseWideViewPort(true);// 支持2.2以上所有版本webSettings.setPluginState(WebSettings.PluginState.ON);// 允许加载Assets和resources文件webSettings.setAllowFileAccess(true);// 告诉webview启用应用程序缓存apiwebSettings.setAppCacheEnabled(true);// 排版适应屏幕webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NARROW_COLUMNS);// 支持插件webSettings.setPluginState(WebSettings.PluginState.ON);// 设置是否启用了DOM storage AP搜索IwebSettings.setDomStorageEnabled(true);// 设置缓存,默认不使用缓存-有缓存,使用缓存webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);// 是否允许缩放webSettings.setSupportZoom(false);// 是否支持通过js打开新的窗口webSettings.setJavaScriptCanOpenWindowsAutomatically(true);// 允许加载JSwebSettings.setJavaScriptEnabled(true);
// 隐藏滚动条webView.setScrollBarStyle(WebView.SCROLLBARS_OUTSIDE_OVERLAY);

3、WebView默认是通过浏览器打开网页,如何使用WebView打开网页?

WebViewClient是WebView的一个重要属性,它不仅仅能够实现WebView打开网页,而且还能够实现URL重构等功能。

// WebView默认是通过浏览器打开url,使用url在WebView中打开webView.setWebViewClient(new WebViewClient() {//    // 旧版本//    @Override//    public boolean shouldOverrideUrlLoading(WebView view, String url) {
        // 使url在WebView中打开,在这里可以进行重构url//        webView.loadUrl(url);//        return true;//    }

    // 新版本
    @Override
    public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {        // 返回false,意味着请求过程中,不管有多少次的跳转请求(即新的请求地址),均交给webView自己处理,这也是此方法的默认处理
        // 返回true,说明你自己想根据url,做新的跳转,比如在判断url符合条件的情况下,我想让webView加载http://baidu.com/
        // 加载Url,使网页在WebView中打开,在这里可以进行重构url
        if(Build.VERSION.SDK_INT>= Build.VERSION_CODES.LOLLIPOP) {
            webView.loadUrl(request.getUrl().toString());
        }        return true;
    }    // WebViewClient帮助WebView去处理页面控制和请求通知
    @Override
    public void onLoadResource(WebView view, String url) {        super.onLoadResource(view, url);
    }    // 错误代码处理,一般是加载本地Html页面,或者使用TextView显示错误
    @Override
    public void onReceivedError(WebView view, WebResourceRequest request, WebResourceError error) {        // 当网页加载出错时,加载本地错误文件//      webView.loadUrl("file:///android_asset/error.html");
    }    // 页面开始加载-例如在这里开启进度条
    @Override 
    public void onPageStarted(WebView view, String url, Bitmap favicon) {        super.onPageStarted(view, url, favicon);
    }    // 页面加载结束,一般用来加载或者执行javaScript脚本
    @Override
    public void onPageFinished(WebView view, String url) {        super.onPageFinished(view, url);
    }
});

4、设置WebView的WebChromeClient属性

WebChromeClient是WebView中一个非常重要的属性,使用它可以监听网页加载的进度,获取网页主题等信息。

// 监听网页加载进度webView.setWebChromeClient(new WebChromeClient() {    // 网页Title信息
    @Override
    public void onReceivedTitle(WebView view, String title) {        super.onReceivedTitle(view, title);
    }    
    // 监听网页alert方法
    @Override
    public boolean onJsAlert(WebView view, String url, String message, JsResult result) {        return super(view, url, message, result);
    }    
    // 显示网页加载进度
     @Override
    public void onProgressChanged(WebView view, int newProgress) {        // newProgress 1-100
    }
});

5、WebView中使用JavaScript

WebView与网页的交互大多数是使用JavaScript来实现

//设置WebView支持JavaScriptWebSettings webSettings = webView.getSettings();
webSettings.setJavaScriptEnabled(true);

6、下载文件监听

// 下载文件webView.setDownloadListener(new DownloadListener() {    @Override 
    public void onDownloadStart(String url, String userAgent, String contentDisposition, String mimetype, long contentLength) {        // url下载文件地址
        // 处理下载文件逻辑
    }
});

7、后退与前进

// 返回键监听@Overridepublic boolean onKeyDown(int keyCode, KeyEvent event) {    if (keyCode == KeyEvent.KEYCODE_BACK) {        if (webView.canGoBack())            // 判断WebView是否能够返回,能-返回
            webView.canGoBack();        else
            finish();        return true;
    }    return super.onKeyDown(keyCode, event);
}

8、WebView优化-缓存

//设置缓存,默认不使用缓存webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);//有缓存,使用缓存webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);//不使用缓存

Github地址

[开心一刻]
开心一刻

原文链接:http://www.apkbus.com/blog-613740-72369.html

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP