最近总想着写一个模拟alert和confirm插件,代替原生的
github: https://github.com/tong-mikasa/msgbox-confirm
主要js代码,scss代码
(function($) {
$.MsgBox = {
Alert: function (title, msg, callback) {
this._generateMsgboxHtml("alert", title, msg);
//$("body").append(Handlebars.compile(this._tplMsgHtm)({type: "alter", title: title, msg: msg}));
this._btnMsgOk(callback);
},
Confirm: function (title, msg, callback,cancelCallback) {
this._generateMsgboxHtml("confirm", title, msg);
//$("body").append(Handlebars.compile(this._tplMsgHtm)({type: "confirm", title: title, msg: msg}));
this._btnMsgOk(callback);
this._btnMsgNo(cancelCallback);
},
CustomizeConfirm: function (title, msg, leftButtonText,rightButtonText,callback,cancelCallback) {
this._generateMsgboxHtml("confirm", title, msg,leftButtonText,rightButtonText);
//$("body").append(Handlebars.compile(this._tplMsgHtm)({type: "confirm", title: title, msg: msg}));
this._btnMsgOk(callback);
this._btnMsgNo(cancelCallback);
},
_tplMsgHtm: $("#tpl_confirm_msgbox").html(),
_btnMsgOk: function(callback) {
var that = this;
$("#msg_btn_ok").click(function () {
that._removeMsgboxPopupWrap();
if (callback && typeof (callback) == 'function') {
callback();
}
});
},
_btnMsgNo: function(cancelCallback) {
var that = this;
$("#msg_btn_no").click(function () {
that._removeMsgboxPopupWrap();
if (cancelCallback && typeof (cancelCallback) == 'function') {
cancelCallback();
}
});
},
_generateMsgboxHtml: function (type, title, msg,leftButtonText,rightButtonText) {
var okButtonText = (typeof leftButtonText == "undefined") ? '确定' : leftButtonText
, noButtonText = (typeof rightButtonText == "undefined") ? '取消': rightButtonText;
var strHtm ='<div class="confirm-msgbox-popup-wrap">' +
' <div class="confirm-mask-bg"></div>' +
' <div id="confirm_content_wrap">' +
' <div class="msg-in">' +
' <div id="msg_header" class="text-center">' +
' <span id="msg_title">'+title+'</span>' +
' </div>' +
' <div id="msg_msg" class="text-center">' + msg + '</div>' +
' <div id="msg_btn_wrap" class="text-center">';
if(type == "alert")
{
strHtm += '<span id="msg_btn_ok" class="msg-btn cursor-point col-full">'+okButtonText+'</span>';
}
if(type == "confirm"){
strHtm += '<span id="msg_btn_ok" class="msg-btn cursor-point col-half">'+okButtonText+'</span>';
strHtm +='<span id="msg_btn_no" class="msg-btn cursor-point col-half">'+noButtonText+'</span>';
}
strHtm +=' </div>' +
' </div>' +
' </div>' +
' </div>';
this._removeMsgboxPopupWrap();
$("body").append(strHtm);
},
_removeMsgboxPopupWrap: function(){
$(".confirm-msgbox-popup-wrap").remove();
}
};
})(jQuery);
/*
<script type="text/x-handlebars-template" id="tpl_confirm_msgbox">
<div class="confirm-msgbox-popup-wrap">
<div class="confirm-mask-bg"></div>
<div id="confirm_content_wrap">
<div class="msg-in">
<div id="msg_header" class="text-center">
<span id="msg_title">{{title}}</span>
</div>
<div id="msg_msg" class="text-center">
{{msg}}
</div>
<div id="msg_btn_wrap" class="text-center">
{{#ifCond type '==' 'alert'}}
<span id="msg_btn_ok" class="msg-btn cursor-point col-full">xxx</span>
{{/if}}
{{#ifCond type '==' 'confirm'}}
<span id="msg_btn_ok" class="msg-btn cursor-point col-half">xxx</span>
<span id="msg_btn_no" class="msg-btn cursor-point col-half">xxx</span>
{{/ifCond}}
</div>
</div>
</div>
</div>
</script>
*/
.confirm-msgbox-popup-wrap{
position: fixed;
left: 0;
top: 0;
z-index: 9990;
width: 100%;
height: 100%;
.col-full{
width: 100%;
}
.col-half{
width: 50%;
}
.cursor-point{
cursor: pointer;
}
.confirm-mask-bg{
position: absolute;
z-index: 9991;
top: 0;
left: 0;
bottom: 0;
right: 0;
background: rgba(0, 0, 0, 0.8);
}
#confirm_content_wrap{
position: absolute;
z-index: 9999;
left: 50%;
top: 50%;
width: 400px;
height: 250px;
margin: -125px 0 0 -200px;
.msg-in{
background: #ffffff;
border-radius: 14px;
-webkit-border-radius: 14px;
-moz-border-radius: 14px;
}
#msg_header{
padding-top: 15px;
border-top-left-radius: inherit;
border-top-right-radius: inherit;
}
#msg_title{
color: #333333;
text-align: center;
padding: 10px 0 10px;
font-size: 20px;
font-weight: bold;
}
#msg_msg{
color: #000000;
padding: 20px;
vertical-align: middle;
font-size: 16px;
line-height: 1.4;
max-height: 100px;
overflow-y: auto;
}
#msg_btn_wrap{
border-top: 1px solid #e6e6e5;
}
.msg-btn{
padding-top: 12px;
padding-bottom: 12px;
display: inline-block;
font-size: 15px;
color: #ffffff;
border: none;
border-right: 1px solid #e6e6e5;
&:last-child{
border: none;
}
}
#msg_btn_ok{
color: #0079FF;
}
#msg_btn_no{
color: rgba(0, 0, 0, 0.9);
}
}
}
@media screen and (max-width: 1000px) {
.confirm-msgbox-popup-wrap{
#confirm_content_wrap{
left: 10%;
right: 10%;
width: auto;
margin: -125px 0 0 0;
#msg_title{
font-size: 30px;
}
#msg_msg{
padding: 30px;
font-size: 28px;
}
.msg-btn{
padding-top: 20px;
padding-bottom: 20px;
font-size: 28px;
}
}
}
}
最近总想着写一个模拟alert和confirm插件,代替原生的的更多相关文章
- [转]jQuery插件实现模拟alert和confirm
本文转自:http://www.jb51.net/article/54577.htm (function () { $.MsgBox = { Alert: function (title, msg) ...
- 模拟alert和confirm
啥也不说,先上图,有图有真相 :) 现在绝大多数网站都不用自带的alert和confirm了,因为界面太生硬了.因此这个插件就这样产生了... 来看插件的实现代码吧: (function () { $ ...
- 自编jQuery插件实现模拟alert和confirm
现在绝大多数网站都不用自带的alert和confirm了,因为界面太生硬了.因此这个插件就这样产生了自己定制一个的想法...... 啥也不说,先上图,有图有真相 :) 现在绝大多数网站都不用自带的al ...
- 从0开始写一个简单的vite hmr 插件
从0开始写一个简单的vite hmr 插件 0. 写在前面 在构建前端项目的时候,除开基本的资源格式(图片,json)以外,还常常会需要导入一些其他格式的资源,这些资源如果没有第三方vite插件的支持 ...
- 模拟alert,confirm 阻塞状态
/*** * 模拟alert弹窗 * content 为弹框显示的内容 * 确定按钮对应的下面取消关闭显示框 * **/function oAlert(content) { var oWrap = $ ...
- CSS写一个圣诞树Chrome浏览器小插件
一时兴起,突然想写一个Chrome浏览器插件,不知道写啥,就写了一个圣诞树小插件.项目源码>> Chrome浏览器插件 Chrome浏览器插件最主要的是:index.html.manife ...
- 手写一个模拟的ReentrantLock
package cn.daheww.demo.juc.reentrylock; import sun.misc.Unsafe; import java.lang.reflect.Field; impo ...
- 用 python 写一个模拟玩家移动的示例
实例:二维矢量模拟玩家移动 在游戏中,一般使用二维矢量保存玩家的位置,使用矢量计算可以计算出玩家移动的位置,下面的 demo 中,首先实现二维矢量对象,接着构造玩家对象,最后使用矢量对象和玩家对象共同 ...
- JS模拟Alert与Confirm对话框
这2个例子都是用原生JS写的,主要是用JS拼接了界面,并未做过多的事件监听.,样式用了Css3的一些特性. 调用方式则为: //Alert Alert.show('我警告你哦~'); //Confir ...
随机推荐
- cmd 中连接mysql时报'mysql'不是内部或外部命令,也不是可运行的程序或批处理文件,该怎么办?
假设安装的mysql目录是D:\MySQL\MySQL_Server_5.5\第一种方法:如果你打开cmd后直接输入mysql是不行的,需要配置mysql的环境变量,那么就在环境变量中增加D:\MyS ...
- Vmware下CentOs7 桥接模式下配置固定IP
1.安装完CentOS7后 修改虚拟机网络适配器配置:改成桥接模式 2.设置Vmware的 编辑->虚拟网络编辑器 3.重启CentOs7 , 查看网络 # ip addr interface是 ...
- SIP简介
说明:以下内容来着之前下载的一份文档,现将概念部分摘录在BLog,如需要完整文档将放在文件中或留言. SIP简介,第1部分:SIP初探 时间:2006-04-07作者:Emmanuel Proulx浏 ...
- Custom SOLR Search Components - 2 Dev Tricks
I've been building some custom search components for SOLR lately, so wanted to share a couple of thi ...
- 桂林理工大学第十届java程序设计初试竞赛试题
原创 三.程序设计题(不得改变已经给出的部分,允许添加新的辅助函数或类)(共36分) (6分)1.以下函数的功能是判断一个正整数是否为质数,若是返回true,否则返回false.其中参数data为要判 ...
- 通过python实现wc基本功能
---恢复内容开始--- 1.Github项目地址: https://github.com/zhg1998/ww/blob/master/wc.py 2.项目相关要求: 写一个命令行程序,模仿已有wc ...
- django media配置
当我们需要向服务器发送图片或视频,需要对这些媒体文件进行保存时,需要指定保存在哪并将保存的路径添加到路由中. 1.设置settings.py MEDIA_URL = '/media/' MEDIA_R ...
- Android Post方式发送信息和获取URL中的图片
需要Internet权限,AndroidManifest.xml <uses-permission android:name="android.permission.INTERNET& ...
- 构建针对 iOS 和 Android 的原生扩展
第一部分:音量控制入门 http://www.adobe.com/cn/devnet/air/articles/building-ane-ios-android-pt1.html 第二部分: 开发 A ...
- CF|codeforces 280C Game on Tree
题目链接:戳我 大概题意:给一棵树,然后每次可以删除一个子树,问你期望多少次能把整棵树都删完? 概率和期望是个神仙..我不会 对于这个题,我们要有一个前置知识--期望的线性性,就是说总期望的值等于各个 ...