Android WebView的使用方法总结
作者:brycegao321 发布时间:2022-08-23 22:14:02
标签:Android,WebView
Android WebView的使用方法
Android app打开H5页一般要实现如下需求:
1、打开指定url网页;
2、点击链接可以跳转到下一页,并更新标题;
3、按back键或左箭头可以返回上一页;
4、当webview显示的是第一级url时, 按返回键或左箭头关闭当前界面;
5、WebView如何传值给android, 例如使用H5登录成功后返回姓名、token等等字段。
6、支持JavaScript, 支持显示js对话框。
7、无网络时显示默认布局, 以提高用户体验。
8、避免WebView的内存泄漏。
不多说, 看下面代码如何实现上述功能。
参考布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:my="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/activity_main_bg"
android:orientation="vertical">
<com.eloancn.borrower.common.widget.TitleView
android:id="@+id/titleView"
android:layout_width="match_parent"
android:layout_height="50dp"
my:titleText="H5" />
<RelativeLayout
android:id="@+id/rl_webViewContainer"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<!--在代码中添加webView防止内存泄露隐患-->
<LinearLayout
android:id="@+id/neterror_tip"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center_horizontal"
android:visibility="gone">
<ImageView
android:layout_marginTop="110dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/not_found" />
</LinearLayout>
</RelativeLayout>
</LinearLayout>
示例代码:
public class CommonWebViewActivity extends Activity {
private WebView mWebView;
private TitleView mTitleView;
private RelativeLayout mWebViewContainer;
private String title;
private String url;
private LinearLayout neterrorLayout;
private int mFlag; //来源
public static final int FLAG_SIGNATURE = 1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_common_webview_main);
initData();
initView();
setData();
}
@Override
protected void onDestroy() {
super.onDestroy();
mWebView.setWebViewClient(null);
mWebView.setWebChromeClient(null);
mWebViewContainer.removeView(mWebView);
mWebView.removeAllViews();
mWebView.destroy();
}
private void initData() {
url = getIntent().getStringExtra("url");
title = getIntent().getStringExtra("title");
mFlag = getIntent().getIntExtra("flag", 0);
}
private void initView() {
mTitleView = (TitleView) findViewById(R.id.titleView);
mWebViewContainer = (RelativeLayout) findViewById(R.id.rl_webViewContainer);
neterrorLayout = (LinearLayout) findViewById(R.id.neterror_tip);
mWebView = new WebView(getApplicationContext());
LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.MATCH_PARENT);
mWebViewContainer.addView(mWebView, layoutParams);
WebSettings webSettings = mWebView.getSettings();
//设置WebView属性,能够执行Javascript脚本
webSettings.setJavaScriptEnabled(true);
//设置可以访问文件
webSettings.setAllowFileAccess(true);
//设置支持缩放
webSettings.setBuiltInZoomControls(false);
//允许js弹出窗口
webSettings.setJavaScriptCanOpenWindowsAutomatically(true);
mTitleView.setLeftBtnClickListener(new TitleView.OnBtnClickListener() {
@Override
public void onClick(View v) {
if (mWebView.canGoBack()) {
mWebView.goBack();
} else {
finish();
}
}
});
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK) {
if (mWebView.canGoBack()) {
mWebView.goBack();
return true;
}
}
return super.onKeyDown(keyCode, event);
}
private void setData() {
mTitleView.setTitle(title);
mWebView.loadUrl(url);
mWebView.setWebChromeClient(new WebChromeClient(){
@Override
public boolean onJsAlert(WebView view, String url, final String message, final JsResult result) {
//注意,WebView默认不会显示JavaScript的Alert,需要Android实现。
runOnUiThread(new Runnable() {
@Override
public void run() {
//自定义美观的Dialog,仅仅是为了显示message
CustomDialog.Builder builder = new CustomDialog.Builder(CommonWebViewActivity.this);
builder.setTitle("提示");
builder.setMessage(message);
builder.setSingle("知道了", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
dialogInterface.dismiss();
}
});
builder.create().show();
}
});
result.confirm();//这里必须调用,否则页面会阻塞造成假死
return true;
}
@Override
public void onReceivedTitle(final WebView view, final String title) {
super.onReceivedTitle(view, title);
if (FLAG_SIGNATURE == mFlag) {
runOnUiThread(new Runnable() {
@Override
public void run() {
mTitleView.setTitle(title);
}
});
}
}
});
mWebView.setWebViewClient(new WebViewClient() {
@Override
public WebResourceResponse shouldInterceptRequest(WebView view, WebResourceRequest request) {
if (FLAG_SIGNATURE == mFlag) {
Log.d("brycegao", "shouldInterceptRequest url:" + request.getUrl().toString());
if (request.getUrl().toString().contains("wxd://getImage?tenderid=")) {
//可以通过url传值给Android, 即在url里放置想要的参数
runOnUiThread(new Runnable() {
@Override
public void run() {
setResult(RESULT_OK);
finish();
}
});
}
}
return super.shouldInterceptRequest(view, request);
}
@Override
public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
mWebView.loadUrl(url);
return true;
}
@Override
public void onReceivedError(WebView view, WebResourceRequest request, WebResourceError error) {
super.onReceivedError(view, request, error);
if (FLAG_SIGNATURE == mFlag
&& request.getUrl().toString().contains("wxd://getImage?tenderid=")) {
//do nothing
mWebView.setVisibility(View.GONE); //优化体验,避免显示错误信息
} else {
//加载失败
neterrorLayout.setVisibility(View.VISIBLE);
mWebView.setVisibility(View.GONE);
}
}
});
neterrorLayout.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
mWebView.setVisibility(View.VISIBLE);
neterrorLayout.setVisibility(View.GONE);
mWebView.loadUrl(url);
}
});
}
}
来源:http://blog.csdn.net/brycegao321/article/details/52809998


猜你喜欢
- SQLite 数据库简介SQLite 是一个轻量级数据库,它是D. Richard Hipp建立的公有领域项目,在2000年发布了第一个版本
- 前言相信大家在写前端脚本的时候经常会遇到发送数据到后台的情况,但是由于浏览器的限制,不同域名之间的数据是不能互相访问的,那前端怎么和后端如何
- 本文以一个C#的SQL数据库字串操作函数为例,说明如何实现对SQL字符串过滤、检测SQL是否有危险字符、修正sql语句中的转义字符,确保SQ
- 上篇文章中我们介绍了浅谈Spring的两种配置容器,接下来我们就了解下spring中的FactoryBean的相关内容,具体如下。从Sess
- 前言前几天恰好面试一个应届生,问了一个很简单的问题:你了解过Mybatis中有几种传参方式吗?没想到其他问题回答的很好,唯独这个问题一知半解
- 本文实例讲述了Android开发之搜索框SearchView用法。分享给大家供大家参考,具体如下:介绍:SearchView时搜索组件,可以
- 一个完整的http响应包括响应行,若干响应头和响应数据主体三部分构成。如果我们能用响应对象来进行这三部分的处理,就能向客户发送特定的响应数据
- 1. 简单介绍嗨,大家好,今天给想给大家分享一下关于Mybatis-plus 的 Service 层的一些方法的使用。今天没有总结,因为都是
- 一 Flow使用注意事项多个Flow不能放到一个lifecycleScope.launch里去collect{},因为进入collect{}
- 本文实例讲述了C#判断当前程序是否通过管理员运行的方法。分享给大家供大家参考。具体实现代码如下:public bool IsAdminist
- 一、@RestController 注解在 Spring Boot 中的 Controller 中使用 @RestController 注解
- Java 使用getClass().getResourceAsStream()方法获取资源之前想获取一个资源文件做一些处理,使用getCla
- 项目分为前台和后台,前台主要为学生角色、后台主要为管理员角色。管理员添加试题和发布试卷,学生负责在线考试、在线查看成绩和错题记录列表等。管理
- Springboot 内置tomcat禁止不安全HTTP方法1、在tomcat的web.xml中可以配置如下内容让tomcat禁止不安全的H
- 1.如果执行了try块没有异常,则继续运行finally块中的语句,即使try块通过return,break,或者continue于最后的语
- 1、ThreadLocal知识体系本文还是不能免俗,在回答这个问题之前需要先和大家介绍一下ThreadLocal的知识,使大家对Thread
- 目录前言令牌中继令牌难道不能在Feign自动中继吗?实现令牌中继InheritableThreadLocal实现令牌中继总结前言在Sprin
- 一、前言先使用一个模板图片,在图片上添加图片或者文字都可以。二、依赖<dependency> <
- 不说废话了,进入我们今天的主题吧。先贴上前面内容的地址:Android手势ImageView三部曲(一)Android手势ImageView
- Java继承方法重写是Java语言多态的特性,必须满足以下条件在子类中,方法名称与父类方法名称完全相同方法的参数个数和类型完全相同,返回类型