关于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>
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- Android IPC进程间通讯机制
- Android Manifest 用法
- [转载]Activity中ConfigChanges属性的用法
- Android之获取手机上的图片和视频缩略图thumbnails
- Android之使用Http协议实现文件上传功能
- Android学习笔记(二九):嵌入浏览器
- android string.xml文件中的整型和string型代替
- i-jetty环境搭配与编译
- android之定时器AlarmManager
- android wifi 无线调试
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- android 代码实现控件之间的间距
- android FragmentPagerAdapter的“标准”配置
- Android"解决"onTouch和onClick的冲突问题
- android:installLocation简析
- android searchView的关闭事件
- SourceProvider.getJniDirectories