博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
android WebViewClient和WebChromeClient
阅读量:5347 次
发布时间:2019-06-15

本文共 2321 字,大约阅读时间需要 7 分钟。

一、Android之WebViewClient与WebChromeClient的区别ANDROID应用开发的时候可能会用到WEBVIEW这个组件,使用过程中可能会接触到WEBVIEWCLIENT与WEBCHROMECLIENT,那么这两个类到底有什么不同呢?WebViewClient主要帮助WebView处理各种通知、请求事件的,比如:onLoadResourceonPageStartonPageFinishonReceiveErroronReceivedHttpAuthRequestWebChromeClient主要辅助WebView处理Javascript的对话框、网站图标、网站title、加载进度等比如onCloseWindow(关闭WebView)onCreateWindow()onJsAlert (WebView上alert无效,需要定制WebChromeClient处理弹出)onJsPromptonJsConfirmonProgressChangedonReceivedIcononReceivedTitle看上去他们有很多不同,实际使用的话,如果你的WebView只是用来处理一些html的页面内容,只用WebViewClient就行了,如果需要更丰富的处理效果,比如JS、进度条等,就要用到WebChromeClient。更多的时候,你可以这样WebView webView;webView= (WebView) findViewById(R.id.webview);webView.setWebChromeClient(new WebChromeClient());webView.setWebViewClient(new WebViewClient());webView.getSettings().setJavaScriptEnabled(true);webView.loadUrl(url);这样你的WebView理论上就能有大部分需要实现的特色了当然,有些更精彩的内容还是需要你自己添加的二、WebViewClient的方法说明1、public boolean shouldOverrideUrlLoading(WebView view, String url) {        view.loadUrl(url);       return true;  }   在点击请求的是链接是才会调用,重写此方法返回true表明点击网页里面的链接还是在当前的webview里跳转,不跳到浏览器那边。2、public void onReceivedSslError(WebView view, SslErrorHandler handler, android.net.http.SslError error) {handler.proceed();}重写此方法可以让webview处理https请求。3、public boolean shouldOverrideKeyEvent(WebView view, KeyEvent event) {            return super.shouldOverrideKeyEvent(view, event);        }    }重写此方法才能够处理在浏览器中的按键事件。4、 public void onLoadResource(WebView view, String url) {            // TODO Auto-generated method stub            if (DEBUG) {                Log.d(TAG, " onLoadResource ");            }            super.onLoadResource(view, url);        }在加载页面资源时会调用,每一个资源(比如图片)的加载都会调用一次。5、 public void onPageStarted(WebView view, String url, Bitmap favicon) {            // TODO Auto-generated method stub            if (DEBUG) {                Log.d(TAG, " onPageStarted ");            }           if (url.endsWith(".apk")) {                    download(url);//下载处理             }            super.onPageStarted(view, url, favicon);        }在页面加载开始时调用。6、public void onPageFinished(WebView view, String url) {            // TODO Auto-generated method stub            if (DEBUG) {                Log.d(TAG, " onPageFinished ");            }            super.onPageFinished(view, url);        }在页面加载结束时调用。

 

转载于:https://www.cnblogs.com/yaowen/p/5562971.html

你可能感兴趣的文章
angular、jquery、vue 的区别与联系
查看>>
参数范围的选择
查看>>
使用 MarkDown & DocFX 升级 Rafy 帮助文档
查看>>
THUPC2019/CTS2019/APIO2019游记
查看>>
Nodejs Express模块server.address().address为::
查看>>
4.3.5 Sticks (POJ1011)
查看>>
POJ 2960 S-Nim 博弈论 sg函数
查看>>
Dijkstra模版
查看>>
一个简单的插件式后台任务管理程序
查看>>
GDB调试多进程程序
查看>>
组合数
查看>>
CMD批处理延时启动的几个方法
查看>>
转:LoadRunner中web_custom_request 和 web_submit_data的差别
查看>>
HTC G7直刷MIUI开启A2SD+亲测教程
查看>>
shiro的rememberMe不生效
查看>>
const 不兼容的类型限定符问题
查看>>
OpenCV的配置
查看>>
spring Cache + Redis 开发数据字典以及自定义标签
查看>>
成功连上数据库顿感世界美好许多
查看>>
编程注意2
查看>>