- 浏览: 222634 次
文章分类
最新评论
-
lmjmn456:
为什么我的TestHall里面看不到RomeA RomeB R ...
Android 通过反射启动未安装的APK中的Activity -
wangleyiang:
uyerp 写道这样的话,只能将插件的元素显示到Hall中。有 ...
Android 通过反射启动未安装的APK中的Activity -
uyerp:
这样的话,只能将插件的元素显示到Hall中。有什么办法能在不安 ...
Android 通过反射启动未安装的APK中的Activity -
wangleyiang:
提高文学修养 写道不好意思,有时间尝试一下,谢谢!有问题提出来 ...
Android 主题之主题文件夹 -
提高文学修养:
不好意思,有时间尝试一下,谢谢!
Android 主题之主题文件夹
在Android的webview中定制js的alert,confirm和prompt对话框的方法
- 博客分类:
- Android
1.首先继承android.webkit.WebChromeClient实现MyWebChromeClient。
2.在MyWebChromeClient.java中覆盖onJsAlert,onJsConfirm ,onJsPrompt三个方法。
3.在初始化Webview时设置调用webview.setWebChromeClient(new MyWebChromeClient());
4.在Webview载入的html中使用window.alert,window.confirm,window.prompt方法,系统弹出的将是自定义实现的对应对话框。
MyWebChromeClient.java的代码如下:
import android.app.AlertDialog; import android.content.DialogInterface; import android.content.DialogInterface.OnCancelListener; import android.content.DialogInterface.OnClickListener; import android.content.DialogInterface.OnKeyListener; import android.graphics.Bitmap; import android.os.Message; import android.util.Log; import android.view.KeyEvent; import android.webkit.JsPromptResult; import android.webkit.JsResult; import android.webkit.WebChromeClient; import android.webkit.WebView; import android.widget.EditText; public class MyWebChromeClient extends WebChromeClient { @Override public void onCloseWindow(WebView window) { super.onCloseWindow(window); } @Override public boolean onCreateWindow(WebView view, boolean dialog, boolean userGesture, Message resultMsg) { return super.onCreateWindow(view, dialog, userGesture, resultMsg); } /** * 覆盖默认的window.alert展示界面,避免title里显示为“:来自file:////” */ @Override public boolean onJsAlert(WebView view, String url, String message, JsResult result) { final AlertDialog.Builder builder = new AlertDialog.Builder(view .getContext()); builder.setTitle("lizongbo的Android webview测试alert对话 框").setMessage( message).setPositiveButton("确定", null); // 不需要绑定按键事件 // 屏蔽keycode等于84之类的按键 builder.setOnKeyListener(new OnKeyListener() { @Override public boolean onKey(DialogInterface dialog, int keyCode, KeyEvent event) { Log.v("onJsAlert", "keyCode==" + keyCode + "event=" + event); return true; } }); // 禁止响应按back键的事件 builder.setCancelable(false); AlertDialog dialog = builder.create(); dialog.show(); result.confirm();// 因为没有绑定事件,需要强行confirm,否则页面会变黑显示不了内容。 return true; } @Override public boolean onJsBeforeUnload(WebView view, String url, String message, JsResult result) { return super.onJsBeforeUnload(view, url, message, result); } /** * 覆盖默认的window.confirm展示界面,避免title里显示为“:来自file:////” */ @Override public boolean onJsConfirm(WebView view, String url, String message, final JsResult result) { final AlertDialog.Builder builder = new AlertDialog.Builder(view .getContext()); builder.setTitle("Android webview测试confirm对话框").setMessage( message).setPositiveButton("确定", new OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { result.confirm(); } }).setNeutralButton("取消", new OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { result.cancel(); } }); builder.setOnCancelListener(new OnCancelListener() { @Override public void onCancel(DialogInterface dialog) { result.cancel(); } }); // 屏蔽keycode等于84之类的按键,避免按键后导致对话框消息而页面无法再弹出对话框的问题 builder.setOnKeyListener(new OnKeyListener() { @Override public boolean onKey(DialogInterface dialog, int keyCode, KeyEvent event) { Log.i("onJsConfirm", "keyCode==" + keyCode + "event=" + event); return true; } }); // 禁止响应按back键的事件 // builder.setCancelable(false); AlertDialog dialog = builder.create(); dialog.show(); return true; // return super.onJsConfirm(view, url, message, result); } /** * 覆盖默认的window.prompt展示界面,避免title里显示为“:来自file:////” * window.prompt('请输入您的域名地址', '618119.com'); */ @Override public boolean onJsPrompt(WebView view, String url, String message, String defaultValue, final JsPromptResult result) { final AlertDialog.Builder builder = new AlertDialog.Builder(view .getContext()); builder.setTitle("lizongbo的Android webview测试prompt对话框").setMessage( message); final EditText et = new EditText(view.getContext()); et.setSingleLine(); et.setText(defaultValue); builder.setView(et); builder.setPositiveButton("确定", new OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { result.confirm(et.getText().toString()); } }).setNeutralButton("取消", new OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { result.cancel(); } }); // 屏蔽keycode等于84之类的按键,避免按键后导致对话框消息而页面无法再弹出对话框的问题 builder.setOnKeyListener(new OnKeyListener() { @Override public boolean onKey(DialogInterface dialog, int keyCode, KeyEvent event) { Log.i("onJsPrompt", "keyCode==" + keyCode + "event=" + event); return true; } }); // 禁止响应按back键的事件 // builder.setCancelable(false); AlertDialog dialog = builder.create(); dialog.show(); return true; // return super.onJsPrompt(view, url, message, defaultValue, result); } @Override public void onProgressChanged(WebView view, int newProgress) { super.onProgressChanged(view, newProgress); } @Override public void onReceivedIcon(WebView view, Bitmap icon) { super.onReceivedIcon(view, icon); } @Override public void onReceivedTitle(WebView view, String title) { super.onReceivedTitle(view, title); } @Override public void onRequestFocus(WebView view) { super.onRequestFocus(view); } }
原文连接:http://618119.com/archives/2010/12/20/199.html
发表评论
-
避免OOM的一种方式
2014-03-11 09:30 891从网上看到一个避免OOM的方式,创建图片时,使用decod ... -
锁屏操作
2013-11-01 11:29 967从API Level 8开始,添加了一个新的类Device ... -
让Surface中绘制的内容响应用户的交互(状态变化)
2013-10-28 16:54 900被绘制的内容响应用户的交互,简单的看就是绘制内容的状态在用 ... -
在自定义的SurfaceView中绘制内容
2013-10-28 16:53 2871View和SurfaceView都可以用于绘制图形,但各有 ... -
在自定义的View中绘制内容
2013-10-28 10:52 954程序开发中,常常需要完成某一个特殊效果而绘制一些内容。 ... -
获取Bitmap大小
2013-10-08 17:59 1044Bitmap的操作常常会导致OOM(内存溢出)。 在处理B ... -
隐藏键盘的一种处理方法
2013-10-08 15:18 678通过调用系统服务来隐藏键盘的一种处理方法: // 获 ... -
通过系统调用裁剪图片
2013-10-08 15:05 1061分享一个Android源码查看网页:http://andr ... -
拍照,相册获取图片,系统裁剪图片
2013-09-30 12:41 1612获取相册图片的一种写法: Intent intent = ... -
转-Android开发环境搭建篇详尽的教程实例汇
2013-09-27 13:50 761原文:http://wiki.eoe.cn/page/An ... -
一种更改包名的方式-Linux命令
2013-09-27 09:54 1148在Android应用程序中更改包名,可以从文件的角度来解决 ... -
Android 通过反射启动未安装的APK中的Activity
2013-02-05 16:32 8890JAVA反射机制是在运行状态中,对于任意一个类,都能够知道 ... -
Android 判断程序是否是系统程序
2013-02-04 14:12 1666获得Android手机中安装程序是否是系统程序,比较好的方式 ... -
Android R
2013-02-01 16:18 1256import java.lang.reflect.Fiel ... -
Android 主题之主题文件夹
2013-02-01 14:22 1720从文件夹中获得主题资源,然后在程序中做相关调整,下面看一个 ... -
Android 主题之安装的APK主题文件
2013-01-31 17:25 1856Android中应用主题设置 ... -
『转』Android Intent常见应用
2013-01-30 16:46 1369转自:http://blog.csdn.net/spy19 ... -
Android px sp dip转化
2013-01-30 12:53 989一个关于px, sp, dip转化的代码: public ... -
Android 布局
2013-01-30 11:19 1326对Android提供的基本布局控件进行组合,可以实现一些相 ... -
Android 添加动画的标签栏
2013-01-29 23:10 1120运行效果图: 实现原理:标签布局好了以后,标签所在V ...
相关推荐
为了能够处理来自JavaScript的alert、confirm和prompt对话框,我们需要创建一个自定义的WebChromeClient: ```java class MyWebChromeClient extends WebChromeClient { // 覆盖方法 @Override public boolean...
- 使用`WebChromeClient`的`onJsAlert()`、`onJsConfirm()`和`onJsPrompt()`方法处理JavaScript的alert、confirm和prompt对话框。 - `WebView`还提供了`onJsBeforeLoad()`、`onJsTimeout()`等回调,可以监听...
为了正确处理JavaScript的`alert()`、`confirm()`和`prompt()`对话框,以及获取加载进度等信息,你需要为你的WebView设置一个`WebChromeClient`实例。例如: ```java myWebView.setWebChromeClient(new ...
本篇将详细讲解在Android中使用WebView进行JS交互的几种常见方法,以及如何在实际项目中应用这些技术。 1. **注入JavaScript接口(JavaScript Interface)** Android提供了`addJavascriptInterface()`方法,允许...
`WebChromeClient`通常用于处理JavaScript的对话框(如alert、confirm、prompt)、进度信息以及文件选择器。而`WebViewClient`则用于拦截页面的加载事件,比如在页面加载开始、完成或出错时进行相应的处理。通过重写...
3. **`WebViewChromeClient`**:在更复杂的情况下,可以使用`WebChromeClient`来处理JavaScript的异步调用,如`window.confirm()`、`window.prompt()`和`window.alert()`。通过重写`onJsPrompt()`、`onJsAlert()`和`...
你可以重写`onJsAlert`、`onJsConfirm`和`onJsPrompt`来处理JavaScript的alert、confirm和prompt对话框。 2. `WebViewClient`:主要负责页面加载过程中的事件,如页面开始加载、页面加载完成、错误处理等。重写`...
- `WebChromeClient`:处理更复杂的交互,如弹出对话框、处理JavaScript的alert、confirm、prompt等。 3. **Android与WebView的交互**: - **Android调用JavaScript**:使用`WebView.loadUrl("javascript:your...
在Android应用开发中,WebView是一个重要的组件,它允许开发者在应用程序内部展示网页内容。而当涉及到与网页交互时,我们通常会用到WebViewClient和WebChromeClient这两个关键类。它们各自有不同的职责,协同工作以...
- WebChromeClient则处理更复杂的交互,比如提供对话框、加载进度、JavaScript的alert、confirm、prompt等。 3. **处理视频播放**: - 默认情况下,WebView可能不会自动全屏播放视频。我们需要重写...
2. **WebChromeClient**: 提供了与JavaScript交互的一些高级功能,如`onJsAlert()`、`onJsConfirm()`、`onJsPrompt()`用于处理JavaScript的alert、confirm和prompt对话框,以及`onProgressChanged()`跟踪网页加载...
`android捕获js中的dialog事件`这个主题涉及到如何在Android的WebView组件中监听并处理JavaScript弹出的对话框,如alert、confirm和prompt。这篇博文链接指向的是ITEYE上的一篇博客,虽然具体内容无法在此提供,但...
总结,Java和JavaScript在Android中的互调涉及多个层面,包括`WebView`的使用、接口定义、客户端配置以及安全性控制。理解和熟练掌握这些知识点对于开发混合式应用至关重要。通过合理的使用,可以充分利用两者的优势...
可以用来处理JavaScript的`prompt()`对话框,以及`WebChromeClient`的`onJsAlert()`和`onJsConfirm()`方法处理JavaScript的`alert()`和`confirm()`对话框。 最后,我们还可以通过`WebViewClient`的`...
例如,`WebChromeClient.onJsAlert()`、`onJsConfirm()`和`onJsPrompt()`可以捕获并处理JavaScript的alert、confirm和prompt对话框。 2. **postMessage和MessageChannel**:为了使JS能够调用Android,我们需要监听...
2. **WebChromeClient**:更专注于提供高级的交互功能,如显示加载进度条、处理JavaScript的alert()、confirm()、prompt()对话框等。此外,WebChromeClient还提供了evaluateJavascript()方法,可以直接执行...
可以通过实现onProgressChanged方法来显示加载进度条,或者通过onJsAlert、onJsConfirm和onJsPrompt来处理JavaScript的alert、confirm和prompt对话框。 4. **网络请求处理**: 虽然WebView可以处理大部分的网页加载...
我们可以通过重写`onJsAlert`、`onJsConfirm`和`onJsPrompt`方法来响应JavaScript的alert、confirm和prompt对话框。 2. `WebViewClient`: 主要负责处理页面加载的相关事件,如加载开始、加载结束等。我们可以通过...
继承WebChromeClient类,在这个类的3个方法中,分别使用Android的内置控件重写了Js中对应的对话框,就是说对js中的对话框做处理了,就是重写了。 通过Android调用JS处理alert弹出框 、处理confirm弹出框、处理...