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

article/2025/9/16 22:45:49

WebView控件最全使用解析

  • 一、WebView 概述
  • 二、WebView使用基础篇
    • 2.1添加方式
    • 2.2 加载远程网页
    • 2.3 加载本地网页
    • 2.4 加载HTML片段
    • 2.5 WebView 常用方法
  • 三、WebView 进阶篇
    • 3.1 WebSettings类
    • 3.2 WebViewClient类
      • 常见方法
      • 使用案例
    • 3.3 WebChromeClient类
      • 常用方法
      • 使用案例
      • 测试网页

一、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控件

<WebViewandroid: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(){@Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) {view.loadUrl(url);// 强制在当前 WebView 中加载 urlreturn true;}});

三、WebView 进阶篇

3.1 WebSettings类

 WebSettings webSettings = webView.getSettings();//如果访问的页面中要与Javascript交互,则webview必须设置支持JavascriptwebSettings.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的页面,告诉用户程序在等待网络响应@Overridepublic void onPageStarted(WebView view, String url, Bitmap favicon) {super.onPageStarted(view, url, favicon);Log.d("MainActivity", "开始加载");}//作用:在页面加载结束时调用。我们可以关闭loading 条,切换程序动作。@Overridepublic void onPageFinished(WebView view, String url) {super.onPageFinished(view, url);Log.d("MainActivity", "加载结束");}// 链接跳转都会走这个方法@Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) {Log.d("MainActivity", "Url:" + url);view.loadUrl(url);// 强制在当前 WebView 中加载 urlreturn true;}//作用:在加载页面资源时会调用,每一个资源(比如图片)的加载都会调用一次。@Overridepublic void onLoadResource(WebView view, String url) {//设定加载资源的操作}//作用:加载页面的服务器出现错误时(如404)调用。@Overridepublic 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请求的,页面显示空白,需要进行如下设置:@Overridepublic 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(){//作用:获得网页的加载进度并显示@Overridepublic void onProgressChanged(WebView view, int newProgress) {Log.d("MainActivity","newProgress:"+ newProgress );super.onProgressChanged(view, newProgress);}//作用:输出Web 端日志@Overridepublic boolean onConsoleMessage(ConsoleMessage consoleMessage) {Log.d("MainActivity","consoleMessage:"+ consoleMessage.message() );return super.onConsoleMessage(consoleMessage);}//作用:获取Web页中的标题@Overridepublic void onReceivedTitle(WebView view, String title) {super.onReceivedTitle(view, title);Log.d("MainActivity","标题:"+ title);}//作用:获取Web页中的图标@Overridepublic void onReceivedIcon(WebView view, Bitmap icon) {super.onReceivedIcon(view, icon);}//作用:获取Web页中 Js中调用alert()函数,产生的对话框@Overridepublic boolean onJsAlert(WebView view, String url, String message, final JsResult result) {Log.d("MainActivity","onJsAlert:"+ message);return super.onJsAlert(view, url, message, result);}@Overridepublic 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);}@Overridepublic 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>

http://chatgpt.dhexx.cn/article/hPHf0T9U.shtml

相关文章

Android:这是一份全面 详细的Webview使用攻略

前言 现在很多App里都内置了Web网页&#xff08;Hybrid App&#xff09;&#xff0c;比如说很多电商平台&#xff0c;淘宝、京东、聚划算等等&#xff0c;如下图 京东首页 那么这种该如何实现呢&#xff1f;其实这是Android里一个叫WebView组件实现 今天&#xff0c;我将献…

数据字典的代码示例

数据字典UI设计&#xff1a; 设计说明&#xff1a; 1. 该数据字典支持多级节点。 2. 左边是数据字典树&#xff1b;右边是编辑框&#xff0c;可以对某个数据字典及其一级子节点进行编辑。 代码&#xff1a;https://github.com/tinazhao1985/spring-cloud-demo/tree/master/di…

关于SQL数据字典的详解

相信在学习数据库的时候很多人在设计表的时候会将一些数据量少的数据放到一个表里面 然后使数据库的表比较多。但是其实呢我们可以见那先数据固定的数据放在同一个表里面&#xff0c;这样就 可以减少很多表的创建&#xff0c;这就是数据字典 数据字典分两个表&#xff1a; 一个…

Java 数据字典的实现

Java数据字典实现 目录概述需求&#xff1a; 设计思路实现思路分析1.从数据库中字典2.获取字典的数值 拓展实现性能参数测试&#xff1a; 参考资料和推荐阅读 Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip h…

数据字典功能

1. 什么是数据字典 数据字典存储有关数据的来源、说明、与其他数据的关系、用途和格式等信息&#xff0c;它本身就 是一个数据库&#xff0c;存储“关于数据项的数据”。数据字典是个指南&#xff0c;它为数据库提供了“路线图”&#xff0c; 而不是“原始数据”。换句话说&…

数据字典实现

目录 前言 一、创建springboot的工程&#xff0c;pom文件 二、实体类&#xff0c;mapper层&#xff0c;service层&#xff0c;controller层 1.实体类 2.mapper层 3.service层 4.service实现层简称(serviceImpl) 5.controller层 实现效果&#xff1a; 前言 首先在写数据字典之前…

数据库设计之数据字典的使用与设计

如何使用数据字典 文章目录 如何使用数据字典使用场景 :解决方案 :简单解决&#xff1a;企业级理解&#xff1a;数据字典是什么&#xff1a;使用数据字典的优点&#xff1a; 使用场景 : 在平时开发的过程中&#xff0c;特别是在遇到表单时候&#xff0c;我们经常需要为前端提供…

数据库 - 数据字典及其使用

1 数据字典 1.1 什么是数据字典 将如下这些具有相同类型的配置项&#xff0c;配置到系统的数据字典表中&#xff0c;方便系统维护&#xff0c;由超级管理员统一在后台进行数据字典维护&#xff0c;如果用户需求要增加变更配置项&#xff0c;只需要修改数据字典表记录…

字典的数据处理与可视化

数据处理与可视化 字典数据处理实现数据可视化字典 首先,我们先简单了解一下字典。字典是一个无序、可变和有索引的集合。在 Python 中,字典用花括号表示,拥有键和值。如:{‘id’:1211,‘colors’:‘aliceblue’} 。而字典中包含有字典,称为嵌套字典。如:{‘id’:1211,‘…

数据字典及其使用

1 数据字典 1.1 什么是数据字典 将如下这些具有相同类型的配置项&#xff0c;配置到系统的数据字典表中&#xff0c;方便系统维护&#xff0c;由超级管理员统一在后台进行数据字典维护&#xff0c;如果用户需求要增加变更配置项&#xff0c;只需要修改数据字典表记录…

软件工程~数据字典例子解释

软件工程~数据字典&#xff08;个人理解&#xff09; 数据字典&#xff1a;关于数据的信息的集合&#xff0c;也就是对数据流图中包含的所有元素的定义的集合。 如果开发小型软件系统时暂时没有数据字典的处理程序&#xff0c;建议使用卡片形式书写数据字典&#xff0c;这里先看…

java静态内部类单例的好处,你确定你的单例模式真的用对了?

一、什么是单例模式 单例模式是一种常用的软件设计模式&#xff0c;其定义是单例对象的类只能允许一个实例存在。该类负责创建自己的对象&#xff0c;同时确保只有一个对象被创建。一般常用在工具类的实现或创建对象需要消耗资源的业务场景。 单例模式的特点&#xff1a; 1.类构…

Java静态内部类单例模式读取Properties配置文件

在Java开发中&#xff0c;可能需要把一些配置参数写入properties配置文件中&#xff0c;在这里介绍一种通过静态内部类单例模式来读取的properties文件的方式。 1.properties文件配置路径 在resources下新建配置文件test.properties&#xff0c;如果对于Java读取指定资源输入…

单例模式的四种实现方式(饿汉模式、懒汉模式、静态内部类、枚举类)

首先&#xff0c;设计模式是我们程序员在软件开发过程中面临的一般问题的解决方案&#xff0c;通过学习设计模式可以使我们在编程时更加有条理性&#xff0c;同时培养我们写代码的思维能力&#xff0c;从而提高我们的工作效率。接下来就跟着博主的脚步往下走吧~ 大多数程序员可…

设计模式-静态内部类方式被反射破坏和饿汉式单例模式被序列化破坏解决方式

场景 设计模式-单例模式-饿汉式单例模式、懒汉式单例模式、静态内部类在Java中的使用示例&#xff1a; 设计模式-单例模式-饿汉式单例模式、懒汉式单例模式、静态内部类在Java中的使用示例_霸道流氓气质的博客-CSDN博客 上面静态内部类单例模式示例 package com.ruoyi.demo…

内部类加载顺序及静态内部类单例模式

加载一个类时&#xff0c;其内部类是否同时被加载&#xff1f;下面我们做一个实验来看一下。 Java代码 public class Outer { static { System.out.println("load outer class..."); } //静态内部类 static class Stati…

java静态内部类单例模式_单例模式-静态内部类实现及原理剖析

以我的经验为例(如有不对欢迎指正)&#xff0c;在生产过程中&#xff0c;经常会遇到下面两种情况&#xff1a; 1.封装的某个类不包含具有具体业务含义的类成员变量&#xff0c;是对业务动作的封装&#xff0c;如MVC中的各层(HTTPRequest对象以Threadlocal方式传递进来的)。 2.某…

C# 静态内部类单例模式-静态变量何时初始化

对于一个类的静态变量何时初始化&#xff0c;大家都有一个普遍的共识&#xff0c;那就是第一次使用该类时&#xff0c;初始化该类的所有静态变量和静态方法。 /// <summary>/// 只有在第一次使用到Test1的时候&#xff0c;才会初始化Test1.x/// </summary>class Te…

静态内部类实现单例_单例模式详解

概述 单例模式,是一种常用的软件设计模式。在它的核心结构中只包含一个被称为单例的特殊类。通过单例模式可以保证系统中,使用单例模式的类只有一个对象实例。 单例应用场景 Windows系统的任务管理器。Windows系统的回收站。操作系统的文件系统,一个操作系统只能有一个文件系…

使用静态内部类单例模式创建自定义线程池

一、使用场景 1、有时候业务上A端和B端做接口传输消息&#xff0c;B端收到消息后做进一步数据处理&#xff08;持久化或者解析&#xff09;等耗时的操作&#xff0c;如果是同步操作会造成等待、超时等情况。可以先向A端返回一个收到信息的消息&#xff0c;再多线程异步处理数据…