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); } }); } }

以上就是Android Webview的使用方法详解,大家如果有疑问可以留言讨论,或者到本站社区交流,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

时间: 2024-10-08 23:48:31

Android WebView的使用方法总结的相关文章

Android WebView的使用方法及与JS 相互调用

Android WebView的使用方法及与JS 相互调用 1.添加网络权限 <uses-permission android:name="android.permission.INTERNET" /> 2.WebSettings 对访问页面进行设置. WebView mWebView = new WebView(this); WebSettings webSettings = mWebView .getSettings();//支持获取手势焦点,输入用户名.密码或其他 m

关于Android WebView的loadData方法的注意事项分析_Android

loadData()中的html data中不能包含'#', '%', '\', '?'四中特殊字符,出现这种字符就会出现解析错误,显示找不到网页还有部分html代码.需要如何处理呢?我们需要用UrlEncoder编码为%23, %25, %27, %3f .可以使用以下两种代码,data为string类型的html代码1.webView.loadData(URLEncoder.encode(data, "utf-8"), "text/html",  "u

关于Android WebView的loadData方法的注意事项分析

loadData()中的html data中不能包含'#', '%', '\', '?'四中特殊字符,出现这种字符就会出现解析错误,显示找不到网页还有部分html代码.需要如何处理呢?我们需要用UrlEncoder编码为%23, %25, %27, %3f . 可以使用以下两种代码,data为string类型的html代码 1.webView.loadData(URLEncoder.encode(data, "utf-8"), "text/html",  "

Android webView shouldOverrideUrlLoading 方法不执行

问题描述 Android webView shouldOverrideUrlLoading 方法不执行 在android 版本4.4.4以上会执行,测试的4.2.2,4.1.2机器上不会执行: 我要实现的逻辑是点击webview上已经加载好的内容,在shouldOverrideUrlLoading 那里拿到链接地址新开Activity用webview加载,不知道有没有能人异士可以提供解决方案. 解决方案 自己解决了,比较麻烦. 解决方案二: android WebView shouldOverr

andrid-android WebView的canGoBack()方法一直返回true

问题描述 android WebView的canGoBack()方法一直返回true 如题,一个页面上使用webview.canGoBack来判断是否能回退网页,如果可以的话,则执行goBack:如果不行的话,则finish该activity. 但是发现WebView中的网页明明前面没有页面了,判断webView.canGoBack时还是返回true,而执行goBack()时,只是重新刷新这个网页.请问是为什么? 解决方案 这个html页面是不是你自己写的?如果不是,看看上一个页面是不是有重定向

android-Android webview 调用java方法如果参数多了 怎么放呢?

问题描述 Android webview 调用java方法如果参数多了 怎么放呢? 这种方法不行 解决方案 Android Webview中调用本地java方法Android的Webview中,javascript如何调用java方法Android的Webview中,javascript如何调用java方法 解决方案二: onclick="javascript:rec('xxx', xxx, ...)" 解决方案三: 看你传的数据应该是一个对象里面的东西,你可以用gson的tojson

Android webview通过http get下载文件下载两次的现象和解决方法

一.现象 一般通过Android webview进行下载文件的方法是 1.重写DownloadListener的onDownloadStart方法,在onDownloadStart方法中弹出对话框提示用户有新的文件需要下载 2.用户点击确定之后,通过http get下载文件 由于Android webview的实现,以上的下载文件步骤涉及到了两次get的操作.第一次是用户在webview中点击下载链接时,webview自动发送http get请求,这个时候服务器除了将文件信息发送过来之外,会同时

Android WebView使用方法详解 附js交互调用方法_Android

目前很多Android app都内置了可以显示web页面的界面,会发现这个界面一般都是由一个叫做WebView的组件渲染出来的,学习该组件可以为你的app开发提升扩展性. 先说下WebView的一些优点: --可以直接显示和渲染web页面,直接显示网页 --webview可以直接用html文件(网络上或本地assets中)作布局 --和JavaScript交互调用  一.基本使用 首先layout中即为一个基本的简单控件: <WebView android:id="@+id/webView

Android webview和js互相调用实现方法_Android

Android-webview和js互相调用 Android 和 H5 都是移动开发应用的非常广泛.市面上很多App都是使用Android开发的,但使用Android来开发一些比较复杂附属类,提示性的页面是得不偿失的.而H5具有开发速度快,更新不用依赖于App的更新,只需要服务端更新相应的页面即可,所以,App和H5页面相结合就显得尤为重要.而android和H5都不可能每次都是独立存在的,而是相互影响也相互的调用,获取信息等,例如,H5页面要获取App中的用户的基本信息,或者App端要操作H5