今天主要介绍一下Android的一个原生组件-WebView。
在Api中关于这个类的介绍大致就是这是一个可以显示网页的视图,如:

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

显示结果:

还可以加载一些html的字符串,如:

String str = "<html><body>You scored <b>192</b> points.</body></html>";
webView.loadData(str, "text/html", null);

显示结果:

通过这个组件可以在你的Activity中显示网页或者跳转到浏览器上显示网页。上方的例子显示的是跳转到手机浏览器上显示百度界面。在下方WebView的方法介绍中我们会使用WebView的方法限制网页显示在当前Activity上。

下面让我们stepBystep的演示一下WebView的使用。
一、加载网页

1.WebView用来显示网页,使用必须时刻注意我们需要添加网络权限

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

2.在XML布局中添加WebView标签并在Activity中实例化

<WebView
        android:id="@+id/main_webview"android:layout_width="match_parent"android:layout_height="match_parent"/>
webView = (WebView) findViewById(R.id.main_webview);

3.之后我们就可以通过WebView的loadUrl的方法加载一个网页

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

4.但是这样加载的网页会跳转到手机浏览器,如何限制网页显示在当前Activity中,需要设置其浏览器模式为false
添加代码如下:

webView = (WebView) findViewById(R.id.main_webview);
// 设置WebView的客户端
webView.setWebViewClient(new WebViewClient(){@Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) {return false;// 返回false}
});
webView.loadUrl("http://www.baidu.com/");

显示的效果:

这样就简单的加载了一个网页。
WebView还提供了一个抽象类WebSettings来设置其所显示网页的一些基本内容,实例化的方式通过WebView对象的get方法获取

WebSettings webSettings = webView.getSettings();

通过这个类可以设置WebView显示网页的一系列属性
为了查看属性是否生效我特意将WebView显示的网页更换了一下,换成了我们公司的网址,先来看一下不设置一系列属性时显示的网页样式,可以看出界面明显不和手机屏幕适配,很差的用户体验

之后我通过WebSettings类设置了显示出网页的一系列属性

    WebSettings webSettings = webView.getSettings();// 让WebView能够执行javaScriptwebSettings.setJavaScriptEnabled(true);// 让JavaScript可以自动打开windowswebSettings.setJavaScriptCanOpenWindowsAutomatically(true);// 设置缓存webSettings.setAppCacheEnabled(true);// 设置缓存模式,一共有四种模式webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);// 设置缓存路径
//        webSettings.setAppCachePath("");// 支持缩放(适配到当前屏幕)webSettings.setSupportZoom(true);// 将图片调整到合适的大小webSettings.setUseWideViewPort(true);// 支持内容重新布局,一共有四种方式// 默认的是NARROW_COLUMNSwebSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);// 设置可以被显示的屏幕控制webSettings.setDisplayZoomControls(true);// 设置默认字体大小webSettings.setDefaultFontSize(12);

设置完成之后在看一下运行效果:

全部代码:
清单文件:最重要的是不要忘记添加网络权限

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="com.wu.webviewdemo"><uses-permission android:name="android.permission.INTERNET"/><application
        android:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:supportsRtl="true"android:theme="@style/AppTheme"><activity android:name=".MainActivity"><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity></application></manifest>

布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><TextView
        android:layout_width="match_parent"android:layout_height="wrap_content"android:background="#000"android:gravity="center"android:paddingBottom="10dp"android:paddingTop="10dp"android:text="使用WebView"android:textAllCaps="false"android:textColor="#fff" /><WebView
        android:id="@+id/main_webview"android:layout_width="match_parent"android:layout_height="match_parent"/></LinearLayout>

Activity

package com.wu.webviewdemo;import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;public class MainActivity extends AppCompatActivity {private WebView webView;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);webView = (WebView) findViewById(R.id.main_webview);// 设置WebView的客户端webView.setWebViewClient(new WebViewClient(){@Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) {return false;// 返回false}});WebSettings webSettings = webView.getSettings();// 让WebView能够执行javaScriptwebSettings.setJavaScriptEnabled(true);// 让JavaScript可以自动打开windowswebSettings.setJavaScriptCanOpenWindowsAutomatically(true);// 设置缓存webSettings.setAppCacheEnabled(true);// 设置缓存模式,一共有四种模式webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);// 设置缓存路径
//        webSettings.setAppCachePath("");// 支持缩放(适配到当前屏幕)webSettings.setSupportZoom(true);// 将图片调整到合适的大小webSettings.setUseWideViewPort(true);// 支持内容重新布局,一共有四种方式// 默认的是NARROW_COLUMNSwebSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);// 设置可以被显示的屏幕控制webSettings.setDisplayZoomControls(true);// 设置默认字体大小webSettings.setDefaultFontSize(12);webView.loadUrl("http://www.lanou3g.com/");}}

二、加载html字符串

在一些Android开发中会遇到这样一种情况,显示详情页不是一些简单的文字,也不是简单的网页,而是通过接口为我们提供html写好的数据,遇到这种数据我们通常采用的方式是通过WebView加载,这就使用到了WebView的另一个方法

public void loadData(String data, String mimeType, String encoding)

1.首先看一下html的string是什么样的,为了加强说服力并且贴合实际,就没有自己制造字符串(如开篇例子)而是扒了一段网易新闻的内容(老郭和他徒弟的新闻,本人还是很喜欢听郭老师的相声的,毕竟喝酒烫头)

private String body = "<p>  <b>网易娱乐专稿9月7日报道</b>(文/小易)" +" 今日凌晨,郭德纲鹤字辈徒弟在微博发文对德云社表忠心,称自己之前在外私自接活,离开德云社," +"因羞愧两年没有师父郭德纲与师娘联系,本应该被清出师门,但承蒙师父郭德纲不离不弃。" +"随后,郭德纲转发该微博并附文“知错能改善莫大焉”。加上前几天曹云金与何云伟撕郭德纲内幕一事," +"本应告一段落的郭德纲与徒弟的各种纠纷若如此下去,恐难彻底收场。</p><p>  <b>韩鹤晓微博原文:" +"</b></p><p>  2006年考入鹤字科取名鹤晓,2009年6月13日恩师郭德纲先生收我为郭门弟子。" +"数年期间吃、住、学艺在德云基地,师父师娘分文未取。2010年结婚师父师娘给我和爱人赠送了红包与婚戒," +"并在德云基地给我们提供了婚房。2014年9月,我由于个人原因,私自赴外地发展。后来返京羞于面对恩师," +"两年未敢与恩师见面。后到上海发展,2016年6月师父上海演出期间,终于鼓起勇气向师父认错," +"师父宽宏大量原谅了我。时隔两月回京之际,专程上家中看望师娘,并求得了原谅。以鶴晓所犯之错," +"本足可导致“清门”,重修德云家谱之际,蒙恩师不弃,给于“暂留察看”实乃对徒儿网开一面。" +"罪徒鶴晓感念恩师授业之恩、不弃之情。鶴晓虽距京城数千之遥,定当永远心系德云。" +"未敢忘却恩师之谆谆教导,踏实做艺、好好做人!唯愿师父师娘身体安泰!徒儿鶴晓顿首遥拜!</p>";

2.设置一下默认的字符编码,Android中普遍使用UTF-8

WebSettings webSettings = webView.getSettings();
webSettings.setDefaultTextEncodingName("UTF-8");

3.之后调用WebView的loadData方法

webView.loadData(body, "text/html; charset=UTF-8", null);

显示效果如下:

下面是全部代码,布局继续使用(一、加载网页)的,代码部分也没有太大的更改,具体如下:

package com.wu.webviewdemo;import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;public class MainActivity extends AppCompatActivity {private WebView webView;private String body = "<p>  <b>网易娱乐专稿9月7日报道</b>(文/小易)" +" 今日凌晨,郭德纲鹤字辈徒弟在微博发文对德云社表忠心,称自己之前在外私自接活,离开德云社," +"因羞愧两年没有师父郭德纲与师娘联系,本应该被清出师门,但承蒙师父郭德纲不离不弃。" +"随后,郭德纲转发该微博并附文“知错能改善莫大焉”。加上前几天曹云金与何云伟撕郭德纲内幕一事," +"本应告一段落的郭德纲与徒弟的各种纠纷若如此下去,恐难彻底收场。</p><p>  <b>韩鹤晓微博原文:" +"</b></p><p>  2006年考入鹤字科取名鹤晓,2009年6月13日恩师郭德纲先生收我为郭门弟子。" +"数年期间吃、住、学艺在德云基地,师父师娘分文未取。2010年结婚师父师娘给我和爱人赠送了红包与婚戒," +"并在德云基地给我们提供了婚房。2014年9月,我由于个人原因,私自赴外地发展。后来返京羞于面对恩师," +"两年未敢与恩师见面。后到上海发展,2016年6月师父上海演出期间,终于鼓起勇气向师父认错," +"师父宽宏大量原谅了我。时隔两月回京之际,专程上家中看望师娘,并求得了原谅。以鶴晓所犯之错," +"本足可导致“清门”,重修德云家谱之际,蒙恩师不弃,给于“暂留察看”实乃对徒儿网开一面。" +"罪徒鶴晓感念恩师授业之恩、不弃之情。鶴晓虽距京城数千之遥,定当永远心系德云。" +"未敢忘却恩师之谆谆教导,踏实做艺、好好做人!唯愿师父师娘身体安泰!徒儿鶴晓顿首遥拜!</p>";@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);webView = (WebView) findViewById(R.id.main_webview);WebSettings webSettings = webView.getSettings();webSettings.setDefaultTextEncodingName("UTF-8");webView.loadData(body, "text/html; charset=UTF-8", null);}
}

三、改进之处:如何加载html数据带有文字和图片的组合,例如在html组成的字符串中穿插出现图片,而且个数和位置还不一致。目前已经有解决方案,敬请期待之后的博客:图文混排。

Android使用WebView加载网页及数据相关推荐

  1. Android使用WebView加载网页

    在AndroidManifest.xml设置访问网络权限: <span style="font-size:24px;"><span style="fon ...

  2. android 使用webview 加载网页

    1. <WebView android:id="@+id/webView"android:layout_width="fill_parent"androi ...

  3. android动态设置错误页面,Android中替换WebView加载网页失败时的页面

    我们用webView去请求一个网页链接的时候,如果请求网页失败或无网络的情况下,它会返回给我们这样一个页面,如下图所示: 上面这个页面就是系统自带的页面,你觉得是不是很丑?反正小编本人觉得非常丑,很难 ...

  4. android WebView加载网页白屏问题优化处理

    android WebView加载网页白屏问题优化处理 问题描述: 使用webview加载Web界面时,会出现界面白屏的情况.http下通常问题不大,通常https白屏的可能性很大,而且通常没有任何报 ...

  5. webview加载html跳转,WebView加载网页(二)

    WebView加载网页(二) 一.实现目标 1.实现一个页面activity_main.xml,该页面上面有一个TextView和两个WebView,一个WebView显示百度首页,另一个WebVie ...

  6. Android中WebView加载sdcard中的html时提示:ERR_FILE_NOT_FOUND和ERR_ACCESS_DENIED

    场景 Android中WebView加载sdcard中的html显示: Android中WebView加载sdcard中的html显示_BADAO_LIUMANG_QIZHI的博客-CSDN博客 在实 ...

  7. Android中WebView加载本地Html,与JavaScript与Android方法相互传值(续)...

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/u010046908/article/details/51809558 接着上篇Android中Web ...

  8. webview加载网页,tel协议不会调出拨号盘?该如何处理

    webview加载网页,tel协议不会调出拨号盘? 在窗体上放了一个Webview:     public void onCreate(Bundle savedInstanceState) {     ...

  9. Webview加载网页时出现NET::ERR_CACHE_MISS的错误

    当使用webview加载网页时我们会遇到网页加载出错,出现NET::ERR_CACHE_MISS的错误,解决方法只需要在你工程的AndroidManifest.xml文件中加入联网的权限 <us ...

最新文章

  1. 如何在ubuntu上安装nvidia-docker同时与宿主共享GPU cuda加速
  2. 重新想,重新看——CSS3变形,过渡与动画①
  3. 左右躲避障碍-神手ts版本
  4. C++ primer 1.2 初窥输入输出流
  5. java 转jsp_【转】JSP三种页面跳转方式
  6. 揭秘《死者之书》之环境资源及特效创作
  7. 无向图缩点:tarjan点双与边双缩点(模板)
  8. mpvue初体验-用vue开发小程序
  9. __attribute__ 之weak,alias属性
  10. MySQL学习笔记_8_SQL语言基础复习
  11. php注册登录模板,Phpcms V9 管理后台登陆及会员注册登录模板的修改方法
  12. VPP命令行:启动配置,HTTP服务,DPDK配置
  13. java里pom.xml是啥意思_pom.xml详解
  14. Corn Fields——POJ3254状态压缩Dp
  15. geddy mysql_以ToDoList应用来学习Geddy
  16. 最简单的BufferQueue测试程序(九)
  17. 导弹拦截(NOIP2010 普及组第三题)
  18. 经济学和金融学的区别
  19. 计算机网络:网络常用命令的使用及DNS层次查询、SMTP协议分析
  20. 关于解决华硕TUF B360M-PLUS GAMING在WIN10下无网卡驱动的方法

热门文章

  1. 【ChatBot开发笔记】使用LTP(语言技术平台)进行自然语言处理
  2. DS18B20数字温度传感器实验
  3. Nvidia Jetson Nano Developer KIT配置全过程(三):安装pytorch等依赖组件
  4. MySQL中几种常见的函数及具体操作
  5. 【Python】逐步回归
  6. Altium Designer 20 19(入门到精通全38集)四层板智能车PCB设计视频教程AD19 AD20 凡亿----笔记
  7. JavaScript childNodes
  8. Linux 内核编译步骤及配置详解
  9. Windows命令之mklink基础
  10. 用Unity做一个萌萌哒游戏(附资源)