在Android的webview中定做js的alert,confirm和prompt对话框的方法
http://618119.com/archives/2010/12/20/199.html
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;
- /**
- * http://618119.com/archives/2010/12/20/199.html
- */
- //****************************************************************************
- 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:////”
- */
- public boolean onJsAlert(WebView view, String url, String message,
- JsResult result) {
- final AlertDialog.Builder builder = new AlertDialog.Builder(view.getContext());
- builder.setTitle("对话框")
- .setMessage(message)
- .setPositiveButton("确定", null);
- // 不需要绑定按键事件
- // 屏蔽keycode等于84之类的按键
- builder.setOnKeyListener(new OnKeyListener() {
- 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;
- // return super.onJsAlert(view, url, message, result);
- }
- public boolean onJsBeforeUnload(WebView view, String url,
- String message, JsResult result) {
- return super.onJsBeforeUnload(view, url, message, result);
- }
- /**
- * 覆盖默认的window.confirm展示界面,避免title里显示为“:来自file:////”
- */
- public boolean onJsConfirm(WebView view, String url, String message,
- final JsResult result) {
- final AlertDialog.Builder builder = new AlertDialog.Builder(view.getContext());
- builder.setTitle("对话框")
- .setMessage(message)
- .setPositiveButton("确定",new OnClickListener() {
- public void onClick(DialogInterface dialog,int which) {
- result.confirm();
- }
- })
- .setNeutralButton("取消", new OnClickListener() {
- 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.v("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');
- */
- 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("对话框").setMessage(message);
- final EditText et = new EditText(view.getContext());
- et.setSingleLine();
- et.setText(defaultValue);
- builder.setView(et)
- .setPositiveButton("确定", new OnClickListener() {
- public void onClick(DialogInterface dialog, int which) {
- result.confirm(et.getText().toString());
- }
- })
- .setNeutralButton("取消", new OnClickListener() {
- public void onClick(DialogInterface dialog, int which) {
- result.cancel();
- }
- });
- // 屏蔽keycode等于84之类的按键,避免按键后导致对话框消息而页面无法再弹出对话框的问题
- builder.setOnKeyListener(new OnKeyListener() {
- public boolean onKey(DialogInterface dialog, int keyCode,KeyEvent event) {
- Log.v("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);
- }
- }
在Android的webview中定做js的alert,confirm和prompt对话框的方法的更多相关文章
- (转)在Android的webview中定制js的alert,confirm和prompt对话框的方法
1.首先继承android.webkit.WebChromeClient实现MyWebChromeClient. 2.在MyWebChromeClient.java中覆盖onJsAlert,onJsC ...
- 在WebView中加载HTML页面时显示进度对话框的方法
webView.setWebViewClient(new WebViewClient(){ ProgressDialog prDialog; @Overri ...
- 在webView 中使用JS 调用 Android / IOS的函数 Function
最近做一个项目,混合了NativeCode 和 HTML,为了便于JS 调用App的一些方法,统一封装一个Js方法,记录如下 Android 端首先要再WebView中允许JS的调用 WebView ...
- Android原生webview中js交互
http://www.cnblogs.com/android-blogs/p/4891264.html Html页面和Java代码结合的方式一般用在界面经常被更改 的情况下,可以讲html放在网络中, ...
- Android 响应webview中图片的点击事件
最近碰到个新需求需要点击webview中的图片进行放大显示. 整理了下思路,想到了下面的一个可行的方案. 方案思路, 1.在点击图片的时候调用本地的java方法并给出响应的图片地址 2.本地获得图片地 ...
- 【Android】java中调用JS的方法
最近因为学校换了新的教务系统,想做一个模拟登陆功能,发现登陆的账号和密码有一个js脚本来进行加密 整理了一下java中执行JS的方法 智强教务 账号 密码 加密方法 var keyStr = &quo ...
- WebView中打开相机,文件选择器的问题和解决方法
近几年前端开发真是越来越火,H5页面开发的移动端页面甚至有夺我原生开发半壁江山的意思,忧伤忧伤.不过从实际情况考虑,H5一套代码到处跑的特性,我们的Android, IOS ...也就只能呵呵了.然而 ...
- salesforce零基础学习(一百二十)快去迁移你的代码中的 Alert / Confirm 以及 Prompt吧
本篇参考: https://developer.salesforce.com/blogs/2022/01/preparing-your-components-for-the-removal-of-al ...
- Android 在webView中创建web应用(译文)
如果你想在客户端添加一个web应用程序或者仅仅一个web页面,你可以通过使用WebView,WebView是基于android中View的扩展,能够在Activity的layout中实现显示网页,它不 ...
随机推荐
- [Json.net]Linq to Json
引言 上篇学习了json.net的基本知识,这篇学习linq to json. 上篇文章:[Json.net]快速入门 Linq to Json Linq to Json是用来快速操作json对象的, ...
- Linq之求和,平均值,最大值,最小值
写在前面 最近一直在弄统计的内容,和统计相关的操作,就需要用到了,而有些在数据库中操作起来非常不方便,没办法就用c#中的linq来实现了. 代码 一个例子 using System; using Sy ...
- [Linux主机] 优化你的php-fpm(php5.3+)让你的网站跑得更快
从php5.3以后php自带了php-fpm不是和php5.2一样以插件的方式存在了.这给我们带来一个好处502没有那么容易出现了坛子里用linux的绝大多数应该还是在用小军的lnmp的那个包,但是配 ...
- selenium常见的疑问和问题
.确认(verifation)和断言(assert)有什么区别? 确认:当测试中的一个用例存在错误时,系统将会继续运行这些测试 断言:当测试中的一个用例存在错误时,系统将会退出当前用例 总而言之 ...
- 可视化HTML编辑器
[荐] 可视化HTML编辑器 CKEditor CKEditor是新一代的FCKeditor,是一个重新开发的版本.CKEditor是全球最优秀的网页在线文字编辑器之一,因其惊人的性能与可扩展性而广泛 ...
- Teradata SQL tips
Question: Insert into table_name (1),(2),.... Teradata 貌似不能同时插入,只能一条一条插入,报错. 后来改为: Insert into tabl ...
- opencv笔记2:图像ROI
time:2015年 10月 03日 星期六 12:03:45 CST # opencv笔记2:图像ROI ROI ROI意思是Region Of Interests,感兴趣区域,是一个图中的一个子区 ...
- hihocoder 1196 高斯消元.二
传送门 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 在上一回中,小Hi和小Ho趁着便利店打折,买了一大堆零食.当他们结账后,看到便利店门口还有其他的活动. 店主:买了 ...
- Apple的App Analytics统计平台你必须知道的Q&A整理与翻译
Apple的App Analytics统计平台你必须知道的Q&A整理与翻译 Apple最近在iTunesConnect里最新发布了App Analytics统计平台,提供了现有友盟统计平台和自 ...
- iOS应用支持IPV6
一.IPV6-Only支持是啥? 首先IPV6,是对IPV4地址空间的扩充.目前当我们用iOS设备连接上Wifi.4G.3G等网络时,设备被分配的地址均是IPV4地址,但是随着运营商和企业逐渐部署IP ...