关于WebView的使用js和java的相互调用(包含按返回按钮时,返回上一页而不是推出activity)

原创 2016年06月01日 16:07:33
<span style="font-size:18px;"><span style="font-size:18px;"><span style="font-size:18px;">package com.minle.day09webview;

import android.app.Activity;
import android.app.AlertDialog;
import android.app.AlertDialog.Builder;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.view.KeyEvent;
import android.view.View;
import android.webkit.JsPromptResult;
import android.webkit.JsResult;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Button;
import android.widget.Toast;

public class MainActivity extends Activity implements
		android.view.View.OnClickListener {
	private WebView webView;
	Button btn;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		// 获得webview控件
		webView = (WebView) findViewById(R.id.webView);
		// 获得webView的设置
		WebSettings settings = webView.getSettings();
		settings.setJavaScriptEnabled(true);// 设置支持js语言
		settings.setSupportZoom(true);// 支持缩放
		settings.setBuiltInZoomControls(true); // 支持内置缩放控制
		setWebView();

		btn = (Button) findViewById(R.id.button1);
		btn.setOnClickListener(this);
	}

	private void setWebView() {
		// 设置webview的加载页面的方法 client 客户端 顾客 委托人
		webView.setWebViewClient(new WebViewClient() {
			// 页面加载前
			@Override
			public void onPageStarted(WebView view, String url, Bitmap favicon) {
				System.out.println("页面开始加载" + url);
				super.onPageStarted(view, url, favicon);
			}

			@Override
			public void onPageFinished(WebView view, String url) {
				System.out.println("页面已完成加载" + url);
				super.onPageFinished(view, url);
			}

			// 这里返回true,表示交给浏览器,返回false,表示当前webview自己解决
			@Override
			public boolean shouldOverrideUrlLoading(WebView view, String url) {
				// TODO Auto-generated method stub
				return super.shouldOverrideUrlLoading(view, url);
			}

		});

	}
/////////////////////////////////////////////////////////////////////////////////////////////////////
	@Override
	public void onClick(View v) {
		// TODO Auto-generated method stub
		switch (v.getId()) {
		case R.id.button1:
			// 点击事件
			String url = "http://www.sohu.com/";// 网络资源
			String url_local = "file:///android_asset/jstest.html";// 本地资源格式
			String url_data = "<html><title>1409A</title><body><table><tr><td>用户名</td><td><input type='text' name='username'/></td></tr></table></body></html>";
			// webview加载当前页面
			webView.loadUrl(url);
			// webView.loadUrl(url_local);// 加载本地网络资源
			// webView.loadDataWithBaseURL("about:blank", url_data, "text/html",
			// "UTF-8", null);// 加载本地代码

			// 设置webView如何处理js的弹出框 
			webView.setWebChromeClient(new WebChromeClient() {
				// 返回true表示自己处理 ,本身的弹出框不再使用
				@Override
				public boolean onJsAlert(WebView view, String url,
						String message, final JsResult result) {
					Toast.makeText(MainActivity.this, "   " + message, 0)
							.show();

					AlertDialog.Builder builder = new Builder(MainActivity.this);

					builder.setMessage(message);
					builder.setNegativeButton("确定", new OnClickListener() {

						@Override
						public void onClick(DialogInterface dialog, int which) {
							// TODO Auto-generated method stub
							result.confirm();
						}
					});
					builder.setPositiveButton("取消", new OnClickListener() {

						@Override
						public void onClick(DialogInterface dialog, int which) {
							// TODO Auto-generated method stub
							result.cancel();
						}
					});

					builder.show();
					return true;
				}
				@Override
				// js的确认框
				public boolean onJsConfirm(WebView view, String url,
						String message, JsResult result) {
					// TODO Auto-generated method stub
					return super.onJsConfirm(view, url, message, result);
				}

				// js的对话框
				@Override
				public boolean onJsPrompt(WebView view, String url, String message,
						String defaultValue, JsPromptResult result) {
					// TODO Auto-generated method stub
					return super.onJsPrompt(view, url, message, defaultValue,
							result);
				}

				
				
				
			});
			break;

		default:
			break;
		}
	}
	
	//////////////////////////////////////////////////////////////////////////////////////////////
	
	// 这里做的事按返回键 按两次返回键的效果
	long exitTime;

	@Override
	public boolean onKeyDown(int keyCode, KeyEvent event) {

		
		 // 如果当前webView可以返回上一页 
		if (keyCode == KeyEvent.KEYCODE_BACK &&
		 webView.canGoBack()) 
		{ // webVIew返回上一页 
		 
			webView.goBack(); 
			return true;
		}
	/*	if (keyCode == KeyEvent.KEYCODE_BACK) {
			System.out.println(System.currentTimeMillis());
			if ((System.currentTimeMillis() - exitTime) > 2000) {

				Toast.makeText(MainActivity.this, "再按一次退出程序", 0).show();
				
				exitTime = System.currentTimeMillis();
			} else {

				System.exit(0);
			}
			return true;

		}*/

		return super.onKeyDown(keyCode, event);
	}

}
</span></span></span>


关于webVeiw时 js和java的相互调用

<span style="font-size:18px;"><span style="font-size:18px;">package com.example.day_10_android_js;

import android.annotation.SuppressLint;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.webkit.JsResult;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.Toast;

public class MainActivity extends Activity {

	private WebView webView;

	@SuppressLint("JavascriptInterface")
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		webView = (WebView) findViewById(R.id.webView);
		
		webView.loadUrl("file:///android_asset/jstest.html");
		
		WebSettings settings = webView.getSettings();
		
		//webVIew是否支持js
		settings.setJavaScriptEnabled(true);
		webView.setWebChromeClient(new WebChromeClient(){
			
			/* (non-Javadoc)
			 * @see android.webkit.WebChromeClient#onJsAlert(android.webkit.WebView, java.lang.String, java.lang.String, android.webkit.JsResult)
			 */
			@Override
			public boolean onJsAlert(WebView view, String url, String message,
					JsResult result) {
				// TODO Auto-generated method stub
				return super.onJsAlert(view, url, message, result);
			}
			
		});
		
		//js调用java
		//添加暴露给js的接口//参数一:object对象,实现要被js调用的方法;参数二:暴露给js的接口名
		webView.addJavascriptInterface(new Object(){
			
			@android.webkit.JavascriptInterface//4.0之后要加这个注解
			public void toast(String str){
				Toast.makeText(MainActivity.this, str, 0).show();
			}
			
		}, "jsCallJava");
		
		
	}

	//点击按钮,调用js方法
	public void callJs(View v){
		
		webView.loadUrl("javascript:testJavacallJs('"+"java传过来的"+"')");
		
	}
	

}
</span></span>



js实现按返回键,不返回上一个页面

阻止由于误按退格键,页面返回到上一页。
  • molingduzun123
  • molingduzun123
  • 2015年06月12日 11:42
  • 2987

JS调用Android里面的方法,Android调用JS里面的方法

Android WebView     在公司Android的开发过程中遇到一个新的问题,那就是让Java代码和Javascript代码进行交互,然后在网上找到了关于webView的资料,之前并没...
  • hj563308597
  • hj563308597
  • 2015年04月22日 17:15
  • 57075

Android - webview原生调用js并且得到返回值

说明: webview原生调用js并且得到返回值,这个需求,4.4之前都是通过各种方法实现的,这里有一个博客:Android - webview原生和JavaScript(js)交互的几种方式 ...
  • u012246458
  • u012246458
  • 2016年12月16日 14:47
  • 4392

android Webview中注入js,用于解决第三方页中出现返回事件window.history.go(-1),无法响应问题

问题描述: 平时我们在使用WebView时,出现第三方页中出现返回事件window.history.go(-1),这时点击网页中的返回页面就一直重新刷不能退出当前界面 解决方案: 通过在android...
  • Charles_ZhuYifei
  • Charles_ZhuYifei
  • 2016年04月24日 10:59
  • 2846

android中加载webview自定义的返回键具有返回上一页的功能

在android开发中我们有时候根据项目的需求多少会加载一些webview,加载webview,我们有时候会根据UI来自定义返回键··而这返回键是在webview中具有返回上一页的功能,现在我们就来实...
  • qq_24448923
  • qq_24448923
  • 2016年10月09日 17:20
  • 3726

android webview点击返回键返回上一个html

@Override  public boolean onKeyDown(int keyCode, KeyEvent event) {   if (keyCode == KeyEvent.KEYCO...
  • ChinaGuangZhou000000
  • ChinaGuangZhou000000
  • 2011年10月25日 18:19
  • 40616

Android中WebView返回到上一个网页

  • 2017年04月26日 17:38
  • 7.32MB
  • 下载

android WebView 加载重定向页面无法后退解决方案

项目中需要用webView加载第三方的web页面
  • lastdream
  • lastdream
  • 2014年10月27日 19:35
  • 21802

JS监听手机端浏览器的后退按钮的事件方法

转载地址:http://www.jb51.net/article/89921.htm 首先我们要了解浏览器的history。 大家知道在页面中我们可以使用javascript window...
  • zhengyang7754
  • zhengyang7754
  • 2017年03月17日 11:45
  • 13920

JavaScript监听手机物理返回键

JavaScript没有监听物理返回键的API,所以只能使用 popstate 事件监听。有两个解决办法: 1、返回到指定的页面 pushHistory(); wind...
  • carter_yu
  • carter_yu
  • 2017年08月14日 13:58
  • 2344
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于WebView的使用js和java的相互调用(包含按返回按钮时,返回上一页而不是推出activity)
举报原因:
原因补充:

(最多只允许输入30个字)