WebView入门级别的使用总结

WebView概述:一个用于展示网页的视图控件,在这个类的基础上,你可以滚动你自带的web浏览器,也可以在Activity上简单地展示一些线上的内容。它使用WebKit渲染引擎显示web页面,并且包含了一些方法:通过历史记录向前或向后导航,放大和缩小,执行文本搜索等。

 

使用的注意事项:当不能使用系统默认浏览器就可以使用WebView。默认下,WebView没有提供的类似浏览器部件,不支JavaScript并且web页面报错也被忽略了。如果你的目标只是显示一些HTML 来作为你界面的一部分,这可能不错;除了阅读之外,用户不需要与网页交互,web页面也不需要与用户进行交互。如果你真的想要一个成熟的web浏览器,那么你可能需要通过一个URL意图调用浏览器应用程序,而不是使用WebView。

 

使用前必需添加访问权限

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

简单用法:

在布局中添加WebView

<?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"
>
    <
WebView
       
android:id="@+id/m_webview"
       
android:background="@color/white_color"
       
android:layout_width="match_parent"
       
android:layout_height="match_parent"
>
    </
WebView>
</
LinearLayout>

使用WebView加载网页

WebView myWebView =(WebView) findViewById(R.id.webview);

myWebView.loadUrl("网址");

但是这种简单用法是不够的,我们必需还要做一些事情才能实现某些功能

WebView的3个基本组件

1.  WebSettings

WebSettings用来对WebView做各种设置,可以这样获取WebSettings

WebSettings webSettings =mWebView .getSettings();

常用设置如下

JS处理

JavaScript是一种属于网络的脚本语言,已经被广泛用于Web应用开发,常用来为网页添加各式各样的动态功能,为用户提供更流畅美观的浏览效果。通常JavaScript脚本是通过嵌入在HTML中来实现自身的功能的。

setJavaScriptEnabled(true); //支持js

setPluginsEnabled(true); //支持插件

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

缩放处理

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

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

setSupportZoom(true); //支持缩放,默认为true。是下面那个的前提。

setBuiltInZoomControls(true); //设置内置的缩放控件。这个取决于setSupportZoom(), setSupportZoom(false),则该WebView不可缩放,这个不管设置什么都不能缩放。

setDisplayZoomControls(false); //隐藏原生的缩放控件

内容布局

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

supportMultipleWindows(); //多窗口

文件缓存

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

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

其他设置

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

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

setDefaultTextEncodingName(“utf-8”); //设置编码格式

setPluginState(PluginState.OFF); //设置是否支持flash插件

setDefaultFontSize(20); //设置默认字体大小

 

 

2. WebViewClient

  WebViewClient用来帮助WebView处理各种通知, 请求事件。我们通过继承WebViewClient并重载它的方法可以实现不同功能的定制。

shouldOverrideUrlLoading(WebView view, String url) //在网页上的所有加载都经过这个方法,这个函数我们可以做很多操作。比如获取url,查看url.contains(“add”),进行添加操作

shouldOverrideKeyEvent(WebViewview, KeyEvent event) //处理在浏览器中的按键事件。

onPageStarted(WebViewview, String url, Bitmap favicon) //开始载入页面时调用的,我们可以设定一个loading的页面,告诉用户程序在等待网络响应。

onPageFinished(WebViewview, String url) //在页面加载结束时调用, 我们可以关闭loading 条,切换程序动作。

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

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

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

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

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

onReceivedSslError(WebViewview, SslErrorHandler handler, SslError error) //让webview处理https请求。

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

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

3.WebChromeClient

WebChromeClient用来帮助WebView处理JS的对话框、网址图标、网址标题和加载进度等。同样地, 通过继承WebChromeClient并重载它的方法也可以实现不同功能的定制

 

public void onProgressChanged(WebViewview, int newProgress); //获得网页的加载进度,显示在右上角的TextView控件中

public void onReceivedTitle(WebViewview, String title); //获取Web页中的title用来设置自己界面中的title, 当加载出错的时候,比如无网络,这时onReceiveTitle中获取的标题为”找不到该网页”,

public void onReceivedIcon(WebView view,Bitmap icon); //获取Web页中的icon

public boolean onCreateWindow(WebViewview, boolean isDialog, boolean isUserGesture, Message resultMsg);

public void onCloseWindow(WebViewwindow);

public boolean onJsAlert(WebView view,String url, String message, JsResult result); //处理alert弹出框,html 弹框的一种方式

public boolean onJsPrompt(WebView view,String url, String message, String defaultValue, JsPromptResult result) //处理confirm弹出框

public boolean onJsConfirm(WebView view,String url, String message, JsResult result); //处理prompt弹出框

 

 

 

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值