Android WebView自定义重写js的alert和confirm对话框
2015-08-21 14:45:45  By: dwtedx

在Amdroid应用开发过程中、经常会用到WebView去加载网页、个人一直觉得WebView的alert()对话框太丑了、所以自定义了WebView的对话框

方法是继承android.webkit.WebChromeClient实现MyWebChromeClient

在MyWebChromeClient.java中覆盖onJsAlert、onJsConfirm、onJsPrompt三个方法onJsPrompt方法可不覆盖、在初始化Webview时设置调用webview.setWebChromeClient(new MyWebChromeClient());

在Webview载入的html中使用window.alert,window.confirm,window.prompt方法、系统弹出的将是自定义实现的对应对话框、而不是系统自带的对话框


onJsAlert代码

/**  
 * 覆盖默认的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);  
}


onJsConfirm代码

/** 
 * 覆盖默认的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);  
}  


最后给贴上Demo的源代码、希望对大家有用、有兴趣的哥们可以下载看看

源代码下载链接: http://dwtedx.com/download.html?bdkey=s/1mgMS5ba 密码: k732

若资源对你有帮助、浏览后有很大收获、不妨小额打赏我一下、你的鼓励是维持我不断写博客最大动力

想获取DD博客最新代码、你可以扫描下方的二维码、关注DD博客微信公众号(ddblogs)

或者你也可以关注我的新浪微博、了解DD博客的最新动态:DD博客官方微博(dwtedx的微博)

如对资源有任何疑问或觉得仍然有很大的改善空间、可以对该博文进行评论、希望不吝赐教

为保证及时回复、可以使用博客留言板给我留言: DD博客留言板(dwtedx的留言板)

感谢你的访问、祝你生活愉快、工作顺心、欢迎常来逛逛


快速评论


技术评论

  • 该技术还没有评论、赶快抢沙发吧...
DD记账
top
+