您的位置:首页 > 移动开发

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

2016-06-01 16:07 711 查看
<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>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  android WebView