【Android】WebView控件最全使用解析

2023-10-31

一、WebView 概述

Android WebView控件是一个可以用来显示Web 网页的控件
Android的Webview在4.4之前采用了不webkit内核,4.4后直接使用了Chrome内核。
WebView继承自 AbsoluteLayout,继承关系如下:
在这里插入图片描述

二、WebView使用基础篇

2.1添加方式

在Manifest文件中添加访问权限

<!--    访问网络权限-->
 <uses-permission android:name="android.permission.INTERNET" />
 <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
 <!--    访问sd卡需要添加的权限-->
 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
 <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

并在application节点下添加 android:usesCleartextTraffic="true"

在布局文件里添加一个WebView控件

<WebView
  android:id="@+id/webview"
  android:layout_width="match_parent"
  android:layout_height="match_parent" />

2.2 加载远程网页

WebView webView = findViewById(R.id.webview);
webView.loadUrl("http://csdn.net");

2.3 加载本地网页

首先创建一个普通的html网页

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>WebView Study</title>
</head>
<body>
    <h1>这是H1</h1>
    <h2>这是H2</h2>
    <div>content</div>
</body>
</html>

把上面的html网页添加到Android工程的assert目录或者sd卡中

WebView webView =   findViewById(R.id.webview);
//加载本地assets目录下的网页
webView.loadUrl("file:///android_asset/test.html");
// 加载data/data 目录
webView.loadUrl("file:///data/data/包名/files/test.html");
//加载手机本地的html页面  -- 需要申请sd卡动态权限
webView.loadUrl("file://mnt/sdcard/test.html");

加载SD卡的文件需要申请动态权限,动态权限申请方法:Android 动态权限最全解析

2.4 加载HTML片段

String html = "<!DOCTYPE html>\n" +
        "<html lang=\"en\">\n" +
        "<head>\n" +
        "    <meta charset=\"UTF-8\">\n" +
        "    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n" +
        "    <title>WebView Study</title>\n" +
        "</head>\n" +
        "<body>\n" +
        "    <h1>这是H1</h1>\n" +
        "    <h2>这是H2</h2>\n" +
        "    <div>content</div>\n" +
        "</body>\n" +
        "</html>";
  WebView webView = findViewById(R.id.webview);
  webView.loadData(html, "text/html", "UTF-8");          

效果如下:

在这里插入图片描述

2.5 WebView 常用方法

清除缓存

//清除网页访问留下的缓存
//由于内核缓存是全局的因此这个方法不仅仅针对webview而是针对整个应用程序.
Webview.clearCache(true);

//清除当前webview访问的历史记录
//只会webview访问历史记录里的所有记录除了当前访问记录
Webview.clearHistory()//这个api仅仅清除自动完成填充的表单数据,并不会清除WebView存储到本地的数据
Webview.clearFormData()

WebView 中网页的前进 / 后退

webView.goBack();//跳到上个页面
webView.goForward();//跳到下个页面
webView.canGoBack();//是否可以跳到上一页(如果返回false,说明已经是第一页)
webView.canGoForward();//是否可以跳到下一页(如果返回false,说明已经是最后一页)
    
//以当前的index为起始点前进或者后退到历史记录中指定的steps
//如果steps为负数则为后退,正数则为前进
Webview.goBackOrForward(intsteps) 
//重新加载当前请求
Webview.reload()

本地网页跳转

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>WebView Study</title>
</head>
<body>
<h1>这是H1</h1>
<h2>这是H2</h2>
<div>content</div>
<a href="file:///android_asset/test1.html">页面跳转1</a>
</body>
</html>

解决跳转用默认浏览器打开的问题

webView.setWebViewClient(new WebViewClient(){
         @Override
         public boolean shouldOverrideUrlLoading(WebView view, String url) {
             view.loadUrl(url);// 强制在当前 WebView 中加载 url
             return true;
         }
     });

三、WebView 进阶篇

3.1 WebSettings类

 WebSettings webSettings = webView.getSettings();
 //如果访问的页面中要与Javascript交互,则webview必须设置支持Javascript
 webSettings.setJavaScriptEnabled(true);
//设置自适应屏幕
 webSettings.setUseWideViewPort(true); //将图片调整到适合webview的大小
 webSettings.setLoadWithOverviewMode(false); // 缩放至屏幕的大小
 //缩放操作
webSettings.setSupportZoom(false); //支持缩放,默认为true。是下面那个的前提。
webSettings.setBuiltInZoomControls(true); //设置内置的缩放控件。若为false,则该WebView不可缩放
webSettings.setDisplayZoomControls(false); //隐藏原生的缩放控件

//其他细节操作
//缓存模式如下:
//LOAD_CACHE_ONLY: 不使用网络,只读取本地缓存数据
 //LOAD_DEFAULT: (默认)根据cache-control决定是否从网络上取数据。
 //LOAD_NO_CACHE: 不使用缓存,只从网络获取数据.
 //LOAD_CACHE_ELSE_NETWORK,只要本地有,无论是否过期,或者no-cache,都使用缓存中的数据
webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); //webview缓存设置
webSettings.setAllowFileAccess(true); //设置可以访问本地文件
webSettings.setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口
webSettings.setLoadsImagesAutomatically(true); //支持自动加载图片
webSettings.setDefaultTextEncodingName("utf-8");//设置编码格式
webSettings.setDatabaseEnabled(true)://是否开启数据库缓存

3.2 WebViewClient类

该类作用:处理各种通知 & 请求事件

常见方法

  • onPageStarted(WebView view, String url, Bitmap favicon):WebView 开始加载页面时回调,一次Frame加载对应一次回调。
  • onLoadResource(WebView view, String url):WebView 加载页面资源时会回调,每一个资源产生的一次网络加载,除非本地有当前 url 对应有缓存,否则就会加载。
  • shouldInterceptRequest(WebView view, String url):WebView 可以拦截某一次的 request 来返回我们自己加载的数据,这个方法在后面缓存会有很大作用。
  • shouldOverrideUrlLoading(WebView view, String url):是否在 WebView 内加载页面。
  • onReceivedSslError(WebView view, SslErrorHandler handler, SslError error):WebView ssl 访问证书出错,handler.cancel()取消加载,handler.proceed()对然错误也继续加载。
  • onPageFinished(WebView view, String url):WebView 完成加载页面时回调,一次Frame加载对应一次回调。
  • onReceivedError(WebView view, int errorCode, String description, String failingUrl):WebView 访问 url 出错。

使用案例

webView.setWebViewClient(new WebViewClient() {
     // 作用:开始载入页面调用的,我们可以设定一个loading的页面,告诉用户程序在等待网络响应
     @Override
     public void onPageStarted(WebView view, String url, Bitmap favicon) {
         super.onPageStarted(view, url, favicon);
         Log.d("MainActivity", "开始加载");
     }

     //作用:在页面加载结束时调用。我们可以关闭loading 条,切换程序动作。
     @Override
     public void onPageFinished(WebView view, String url) {
         super.onPageFinished(view, url);
         Log.d("MainActivity", "加载结束");
     }

     // 链接跳转都会走这个方法
     @Override
     public boolean shouldOverrideUrlLoading(WebView view, String url) {
         Log.d("MainActivity", "Url:" + url);
         view.loadUrl(url);// 强制在当前 WebView 中加载 url
         return true;
     }


     //作用:在加载页面资源时会调用,每一个资源(比如图片)的加载都会调用一次。
     @Override
     public void onLoadResource(WebView view, String url) {
         //设定加载资源的操作
     }

     //作用:加载页面的服务器出现错误时(如404)调用。
     @Override
     public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
         switch (errorCode) {
             case 404:
                 view.loadUrl("file:///android_assets/error_handle.html");
                 break;
         }
     }

     //作用:处理https请求
     //webView默认是不处理https请求的,页面显示空白,需要进行如下设置:
     @Override
     public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
         handler.proceed();    //表示等待证书响应
         // handler.cancel();      //表示挂起连接,为默认方式
         // handler.handleMessage(null);    //可做其他处理
     }
 });

3.3 WebChromeClient类

该类作用:辅助 WebView 处理 Javascript 的对话框,网站图标,网站标题等。

常用方法

  • onConsoleMessage(String message, int lineNumber,String sourceID):输出Web 端日志。
  • onProgressChanged(WebView view, int newProgress):当前 WebView
    加载网页进度。
  • onJsPrompt(WebView view, String url, String message, String
    defaultValue, JsPromptResult result):处理 JS 中的 Prompt对话框
  • onJsAlert(WebView view, String url, String message, JsResult result):
    Js 中调用 alert() 函数,产生的对话框。
  • onReceivedTitle(WebView view, String title):接收web页面的 Title。
  • onReceivedIcon(WebView view, Bitmap icon):接收web页面的icon。

使用案例

 webView.setWebChromeClient(new WebChromeClient(){
            //作用:获得网页的加载进度并显示
            @Override
            public void onProgressChanged(WebView view, int newProgress) {
                Log.d("MainActivity","newProgress:"+ newProgress );
                super.onProgressChanged(view, newProgress);
            }

            //作用:输出Web 端日志
            @Override
            public boolean onConsoleMessage(ConsoleMessage consoleMessage) {
                Log.d("MainActivity","consoleMessage:"+ consoleMessage.message() );
                return super.onConsoleMessage(consoleMessage);
            }

            //作用:获取Web页中的标题
            @Override
            public void onReceivedTitle(WebView view, String title) {
                super.onReceivedTitle(view, title);
                Log.d("MainActivity","标题:"+ title);
            }

            //作用:获取Web页中的图标
            @Override
            public void onReceivedIcon(WebView view, Bitmap icon) {
                super.onReceivedIcon(view, icon);
            }

            //作用:获取Web页中 Js中调用alert()函数,产生的对话框
            @Override
            public boolean onJsAlert(WebView view, String url, String message, final JsResult result) {
                Log.d("MainActivity","onJsAlert:"+ message);
                return super.onJsAlert(view, url, message, result);
            }

            @Override
            public boolean onJsPrompt(WebView view, String url, String message, String defaultValue, JsPromptResult result) {
                Log.d("MainActivity","onJsPrompt:"+ message);
                return super.onJsPrompt(view, url, message, defaultValue, result);
            }

            @Override
            public boolean onJsConfirm(WebView view, String url, String message, JsResult result) {
                Log.d("MainActivity","onJsConfirm:"+ message);
                return super.onJsConfirm(view, url, message, result);
            }
        });

测试网页

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>WebView Study</title>
    <script>
        function clickPrompt() {
            prompt("prompt");
        }
        function clickAlert() {
            alert("alert");
        }

        function clicConfirm() {
            confirm("Confirm");
        }
    </script>
</head>

<body>
<button type="button" onclick="clickPrompt()">Prompt调用</button>
<button type="button" onclick="clickAlert()">Alert调用</button>
<button type="button" onclick="clicConfirm()">Confirm调用</button>
</body>

</html>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

【Android】WebView控件最全使用解析 的相关文章

随机推荐

  • 项目应用:使用自定义注解完成对controller的aop控制

    在项目进行过程中 需要使用aop对api传入或者传出数据进行日志记录 考虑实际应用 放弃了使用拦截器 转而使用aop的前置通知和返回通知中加入日志记录操作 在spring中 controller会被JDK自动代理 当使用自定义标签时cont
  • R语言的基本数据类型:数值,字符串,逻辑

    R语言的基本数据类型 数值 双整型 储存普通数值型数据 可正可负 可大可小 可含小数可不含 R中输入的任何一个数值都默认以双整型存储 可以使用typeof 函数来查看对象类型 在数据科学里 它更常被称为数值型 整型 只能用来储存正数 在R中
  • 前端面试题之——兼容篇

    兼容性面试题 一 html 部分 1 H5 新标签在 IE9 以下的浏览器识别 html5shiv js 下载地址 2 ul 标签内外边距问题 ul 标签在 IE6 IE7 中 有个默认的外边距 但是在 IE8 以上及其他浏览器中 有个默认
  • websphere6.x 调用集群EJB的Context.PROVIDER_URL写法

    import java util Hashtable import javax naming Context import javax naming InitialContext Hashtable env new Hashtable en
  • caffe源码解析 — net.cpp

    Net类是Solve类的一个成员 在net cpp中定义了对Net的所有操作 其中包括 Init GetLearningRateAndWeightDecay ForwardPrefilled Backward ShareTrainedLay
  • 计算机数值转换教案,计算机数值方法教案.doc

    第O章 绪论 一 教学设计 1 教学内容 数值计算方法这门课程的形成背景及主要研究内容 研究方法 主要特点 算法的有关概念及要求 误差的来源 意义 及其有关概念 数值计算中应注意的一些问题 2 重点难点 算法设计及其表达法 误差的基本概念
  • 数据结构——快速排序

    1 原理及代码实现 快速排序 快速排序也是一种分治的排序算法 快速排序和归并排序是互补的 归并排序将数组分成两个子数组分别排序 并将有序的子数组归并以将整个数组排序 会需要一个额外的数组 而快速排序的排序方式是当两个子数组都有序时 整个数组
  • @Async注解线程池

    在启动类上添加 EnableAsync配合该注解使用 自定义线程池方法 implements AsyncConfigurer extends AsyncSupportConfigurer Bean 注入线程池 public interfac
  • Shell中表示数字跨度的几种方式

    在Shell脚本中 如果要输出数字为0 20中3的倍数 可以使用下面三种方式来完成 方式一 i 0 i lt 20 i 3 for i 0 i lt 20 i 3 do echo i done 方式二 0 20 3 for i in 0 2
  • ElasticSearch 评分排序

    背景 通过脚本改变评分 背景 近期有一个需求 需要对优惠券可用商品列表加个排序 只针对面值类的券不包括折扣券 需求是这样的 假设有一张面值券 50 块钱 可用商品列表 A 100 B 40 C 10 当用户查询当前券可用商品列表的时候优先将
  • RuntimeError: expected dtype Double but got dtype Float 损失求导出错

    求导出现问题 源代码 修改为 把损失修改为loss clone detach requires grad
  • 卫星通信的资源调度 vs 地面无线通信的资源调度

    以OFDM系统为例 考虑多个用户共用多个子载波的场景 一 两类资源 调整时频资源 即基站或卫星决定给各个用户在哪些时隙分配多少子载波 调整发射功率 即基站或卫星决定给每个用户在每个子信道上的功率是多大 用字母 P n k P n k Pn
  • 【TestNG】TestNG使用教程详解

    一 TestNG介绍 TestNG是Java中的一个测试框架 类似于JUnit 和NUnit 功能都差不多 只是功能更加强大 使用也更方便 详细使用说明请参考官方链接 https testng org doc index html 二 Te
  • anaconda 创建虚拟环境、激活及使用的基本方法

    1 查看当前存在的虚拟环境 conda env list 2 创建虚拟环境 环境名 conda create n 环境名 python X X 3 激活指定虚拟环境 activate 环境名 4 删除虚拟环境 conda remove n
  • c++ 鼠标控制

    windows下获得鼠标位置和控制鼠标 include
  • 使用nodejs开发一个markdown文档管理小系统(一)Using Nodejs to quickly develop a markdown management system...

    好多年没碰过前端jquery了 用一两天时间重温一下 刚好写个小工具 不递归取文件夹和文件 只写一层 保持足够简单 验证和参数判断暂不写 毕竟只写了几个小时而已 功能算完备了 添加一个简单的管理员权限管理修改的所有功能即可放出去了 看来还不
  • LaTeX各种算法排版

    1 首先在导言区加入语句 usepackage algorithm usepackage algorithmic 2 例1 begin algorithm caption A label alg A begin algorithmic ST
  • AUTOSEMO“恒以致远,共创共赢”主题研讨会圆满落幕

    2023年8月31日 中国汽车工业协会软件分会中国汽车基础软件生态标委会 简称 AUTOSEMO 与天津市西青区人民政府联合主办 北京经纬恒润科技股份有限公司承办的 恒以致远 共创共赢 主题研讨会在天津隆重召开 本次研讨会是AUTOSEMO
  • vue2.0使用less 创建全局的颜色变量,配置主题色

    1 使用场景 项目中需要统一配置前端的主题样式 我们可以使用less创建 theme colors rgba 54 174 149 1 变量 供全局调用 2 安装依赖 cnpm install less less loader save 安
  • 【Android】WebView控件最全使用解析

    WebView控件最全使用解析 一 WebView 概述 二 WebView使用基础篇 2 1添加方式 2 2 加载远程网页 2 3 加载本地网页 2 4 加载HTML片段 2 5 WebView 常用方法 三 WebView 进阶篇 3