jquery模拟alert的弹窗插件
更新时间:2015年07月31日 11:37:34 投稿:hebedich
这篇文章主要介绍了jquery模拟alert的弹窗插件的相关资料,需要的朋友可以参考下
演示地址:
http://runjs.cn/detail/miwszbne
分享说明:
第N次造轮子了,只为最简单的调用,jquery模拟alert和confirm的弹窗插件
调用方法:
$.alert('your message'); $.alert('your message',function(){ $.alert('click ok button') }); $.confirm('your message'); $.confirm('your message',function(result){ if(result){ $.alert('click ok button') }else{ $.alert('click cancel button') } })
为了调用方便,直接将css样式写在了js中,兼容性方面只测试了IE8和chrome以及safari,都还可以。
IE8没问题想必其他现代浏览器应该也是OK的。
(function ($) { $.extend({ _isalert:0, alert:function(){ if(arguments.length){ $._isalert=1; $.confirm.apply($,arguments); } }, confirm:function(){ var args=arguments; if(args.length&&(typeof args[0] == 'string')&&!$('#alert_overlay').length){ if(!$('#alert_style').length) $('body').append('<style id="alert_style" type="text/css">#alert_overlay{position:fixed;width:100%;height:100%;top:0;left:0;z-index:999;background:#000;filter:alpha(opacity=5);opacity:.05}#alert_msg{position:fixed;width:400px;margin-left:-201px;left:50%;top:20%;z-index:1000;border:1px solid #aaa;box-shadow:0 2px 15px rgba(0,0,0,.3);background:#fff}#alert_content{padding:20px;font-size:14px;text-align:left}#alert_buttons{padding:10px;border-top:1px solid #aaa;text-align:right;box-shadow:0 1px 0 #fff inset;background:#eee;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none}#alert_buttons .alert_btn{padding:5px 12px;margin:0 2px;border:1px solid #aaa;background:#eee;cursor:pointer;border-radius:2px;font-size:14px;outline:0;-webkit-appearance:none}#alert_buttons .alert_btn:hover{border-color:#bbb;box-shadow:0 1px 2px #aaa;background:#eaeaea}#alert_buttons .alert_btn:active{box-shadow:0 1px 2px #aaa inset;background:#e6e6e6}</style>'); var dialog=$('<div id="alert_overlay"></div><div id="alert_msg"><div id="alert_content">'+args[0]+'</div><div id="alert_buttons"><button class="alert_btn alert_btn_ok">确定</button><button class="alert_btn alert_btn_cancel">取消</button></div></div>'); if($._isalert) dialog.find('.alert_btn_cancel').hide(); dialog.on('contextmenu',function(){ return !1; }).on('click','.alert_btn_ok',function(){ dialog.remove(); if(typeof args[1]=='function') args[1].call($,!0); }).on('click','.alert_btn_cancel',function(){ dialog.remove(); if(typeof args[1]=='function') args[1].call($,!1); }).appendTo('body'); } $._isalert=0; } }); })($);
以上所述就是本文的全部内容了,希望大家能够喜欢。
相关文章
关于jquery append() html时的小问题的解决方法
关于jquery append() html时的小问题,碰到类似问题的朋友可以参考下。2010-12-12jquery的ajax提交form表单的两种方法小结(推荐)
下面小编就为大家带来一篇jquery的ajax提交form表单的两种方法小结(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考2016-05-05jQuery中ajax请求后台返回json数据并渲染HTML的方法
今天小编就为大家分享一篇jQuery中ajax请求后台返回json数据并渲染HTML的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-08-08jquery使用slideDown实现模块缓慢拉出效果的方法
这篇文章主要介绍了jquery使用slideDown实现模块缓慢拉出效果的方法,涉及slideDown方法操作模块展示效果的技巧,具有一定参考借鉴价值,需要的朋友可以参考下2015-03-03
最新评论