`

模拟Window Alert弹出框 支持拖动以及ESC键盘退出

阅读更多

基本我自己封装的一些常用函数:KW.js

 

/*
Kingwell Javascript library
Author:Jinhua.leng#gmail.com
Date:2012-05-20
*/
(function () {
	if (!window.KW) {
		window.KW = {}
	} //命名空间
	
	window.KW = {
		
                 version:"V1.02",
		$ : function () { //$()函数
			var elements = new Array();
			for (var i = 0; i <= arguments.length; i++) {
				var element = arguments[i];
				//如果是一个字符串那假设它是一个ID
				if (typeof element == 'string') {
					element = document.getElementById(element);
				}
				//如果只提供了一个参数,则立即返回这个参数
				if (arguments.length == 1) {
					return element;
				}
				//否则,将它添加到数组中
				elements.push(element);
			}
			return elements;
		},
		
		/*-------------------- 事件处理 --------------------*/
		addEvent : function (oTarget, oType, fnHandler) { //-----添加事件;
			var oT = this.$(oTarget);
			if (!oT) {
				alert('Not found \" ' + oTarget + ' \"');
				return false
			};
			if (oT.addEventListener) { //for DOM
				oT.addEventListener(oType, fnHandler, false);
			} else if (oT.attachEvent) { //for IE
				oT.attachEvent('on' + oType, fnHandler);
			} else { //for Others
				oT['on' + oType] = fnHandler;
			}
		},
		removeEvent : function (oTarget, oType, fnHandler) { //-----移除事件;
			var oT = this.$(oTarget);
			if (!oT) {
				alert('Not found \" ' + oTarget + ' \"');
				return false
			};
			if (oT.removeEventListener) { //for DOM
				oT.removeEventListener(oType, fnHandler, false);
			} else if (oT.detachEvent) { //for IE
				oT.detachEvent('on' + oType, fnHandler);
			} else { //for Others
				oT['on' + oType] = null;
			}
		},
		getEvent : function () { //-----获得事件-----
			return window.event || arguments.callee.caller.arguments[0];
		},
		getTarget : function () { //-----获取目标----
			var ev = window.event || arguments.callee.caller.arguments[0];
			return ev.srcElement || ev.target;
		},
		stopPropagation : function () { //-----阻止冒泡-----
			if (window.event) {
				return this.getEvent().cancelBubble = true;
			} else {
				return arguments.callee.caller.arguments[0].stopPropagation();
			}
		},
		stopDefault : function () { //-----阻止默认行为
			if (window.event) {
				return this.getEvent().returnValue = false;
			} else {
				return arguments.callee.caller.arguments[0].preventDefault();
			}
		},
		
		/*-------------------- 常用函数 --------------------*/
		toggleDisplay : function (id) { //-----显示,隐藏-----
			var oTarget = this.$(id);
			if (!oTarget) {
				return false;
			}
			oTarget.style.display == 'none' ? oTarget.style.display = 'block' : oTarget.style.display = 'none';
		},
		stripHTML : function (agr) { //-----移除HTML-----
			var reTag = /<(?:.|\s)*?>/g;
			return agr.replace(reTag, '')
		},
		stripSpace : function (oTarget) { //-----移除空格-----
			var re = /^\s*(.*?)\s*$/;
			return oTarget.replace(re, '$1');
		},
		isEmail : function (e) { //-----Is E-mail
			var re = /^[a-zA-z_][a-zA-Z_0-9]*?@\w{1,}.\[a-zA-Z]{1,}/;
			return re.test(e);
		},
		
		/*-------------------- DOM --------------------*/
		
		createContent : function (node, value, parendNode) {
			var n = document.createElement(node),
			c = document.createTextNode(value);
			n.appendChild(c);
			document.body.appendChild(n)
		},
		text : function (node, value) {
			this.$(node).innerHTML = value;
		},
		val : function (node, value) {
			this.$(node).value = value
		},
		size : function () {
			return this.size();
		},
		addElement : function (tag, id, value) {
			if (arguments.length <= 1) {
				return document.createElement(tag);
			} else {
				var tag = document.createElement(tag);
				tag.setAttribute(id, value);
				return tag;
			}
		},
		att : function (id, value) {
			if (arguments.length == 1) {
				return this.getAttibute.value;
			} else if (arguments.length == 2) {
				return setAtttube.value;
			} else {
				return false
			}
		},
		
		/*-------------------- Cookie操作 --------------------*/
		setCookie : function (sName, sValue, oExpires, sPath, sDomain, bSecure) { //-----设置Cookie-----
			var sCookie = sName + '=' + encodeURIComponent(sValue);
			if (oExpires) {
				sCookie += '; expires=' + oExpires.toGMTString();
			}
			if (sPath) {
				sCookie += '; path=' + sPath;
			}
			if (sDomain) {
				sCookie += '; domain=' + sDomain;
			}
			if (bSecure) {
				sCookie += '; secure';
			}
			document.cookie = sCookie;
		},
		getCookie : function (sName) { //-----获得Cookie值-----
			var sRE = '(?:; )?' + sName + '=([^;]*)';
			var oRE = new RegExp(sRE);
			if (oRE.test(document.cookie)) {
				return decodeURIComponent(RegExp['$1']);
			} else {
				return null;
			}
		},
		deleteCookie : function (sName, sPath, sDomain) { //-----删除Cookie值-----
			this.setCookie(sName, '', new Date(0), sPath, sDomain);
		}
		
	}; //WS End
	
	
})(); //Library End
 

 

基本代码:

 

/*-----KW.js调用说明-----
KW.$()           ----->ID选择器;
addEvent         ----->绑定事件;
removeEvent      ----->移除事件;
getEvent         ----->获得事件;
getTarget        ----->获得事件目标;
stopPropagation()----->阻止冒泡
stopDefault()    ----->取消默认事件

 */

/*
弹出框 函数说明
alertBox(sTitle, sContent, sType);
参数:
sTitle:弹出框标题
sContent:弹出框内容,可以是文本,HTML
sType:
 */
function alertBox(sTitle, sContent, sType) {
	
	var cl = document.createElement("div"),
	ac = document.createElement("div"),
	at = document.createElement("div"),
	act = document.createElement("div"),
	clo = document.createElement("span"),
	bh = document.body.offsetHeight;
	cl.setAttribute("id", "cover-layer");
	cl.setAttribute("style", "height:" + bh + "px");
	ac.setAttribute("id", "alert-container");
	at.setAttribute("id", "alert-title");
	act.setAttribute("class", "alert-content");
	clo.setAttribute("id", "alert-close");
	clo.setAttribute("class", "in-bl");
	clo.setAttribute("title", "close")
	
	cl.appendChild(ac);
	ac.appendChild(at);
	at.innerHTML = sTitle;
	at.appendChild(clo);
	ac.appendChild(act);
	act.innerHTML = sContent;
	
	if (sType == "prompt") {
		var ab = document.createElement("div"),
		as = document.createElement("button"),
		ar = document.createElement("button");
		ab.setAttribute("class", "alert-button");
		as.setAttribute("id", "alertSubmit");
		ar.setAttribute("id", "cancel");
		as.innerHTML = "Yes";
		ar.innerHTML = "No";
		ab.appendChild(as);
		ab.appendChild(ar);
		ac.appendChild(ab);
	}
	document.body.appendChild(cl);
	//垂直居中实现
	var ch = Math.ceil(document.documentElement.clientHeight / 2),
	lh = Math.ceil(ac.offsetHeight / 4);
	ac.setAttribute("style", "top:" + ch + "px;margin-top:" + -lh + "px");
	//响应ESC键
	KW.addEvent(document.body, "keyup", function () {
		if (KW.$("cover-layer") && KW.getEvent().keyCode == 27) {
			delAlert();
		}
	})
	if (sType == "prompt") {
		WS.addEvent("cancel", "click", function () {
			delAlert();
		})
	}
	if (sType == "prompt") {
		KW.addEvent("alertSubmit", "click", function () {
			delAlert();
			return true;
		})
	}
	//Drag and Drop
	var x;
	var y;
	var box = KW.$("alert-container");
	box.style.left = box.offsetLeft+"px";
	box.style.top = box.offsetTop+"px";
	WS.addEvent("alert-title", "mousedown", function () {
		x = KW.getEvent().clientX - parseInt(box.style.left);
		y = KW.getEvent().clientY - parseInt(box.style.top)
		WS.addEvent(document.body, "mousemove", mousemove);
		});
	document.onmouseup = function () {
		WS.removeEvent(document.body, "mousemove", mousemove);
	}
	function mousemove() {
		box.style.left= (KW.getEvent().clientX-x) + "px"
		box.style.top = (KW.getEvent().clientY - y) + "px"
	}
} //alertBox End

/*
删除遮盖层;
delAlert();
当需要删除遮盖层时,调整此函数即可;
 */
function delAlert() {
	KW.$("cover-layer").parentNode.removeChild(KW.$("cover-layer"));
}
 

CSS 代码:

 

/*-- Alert --*/
#cover-layer{position:absolute; top:0; left:0; margin:auto; width:100%; height:100%; background:rgba(0,0,0,0.2); _background:#000; z-index:10000;}
#cover-layer #alert-container{width:400px; position:absolute; left:50%; margin-left:-100px; top:50%; background:#FFF; box-shadow:0 0 30px rgba(0,0,0,0.6); border-radius:5px;}
#cover-layer #alert-title{line-height:30px; padding:0 10px; font-weight:bold; border-top-left-radius:5px; border-top-right-radius:5px; background:#EEE; background:-moz-linear-gradient(#FFF,#EEE); background:-webkit-gradient(linear,0% 0%,0% 100%,from(#FFF),to(#EEE)); cursor:move}
#cover-layer .alert-content{padding:30px 20px;}
#cover-layer .alert-button{margin:auto auto 10px auto; text-align:center;}
#cover-layer button{min-width:50px; margin:auto 5px}
#cover-layer #alert-close{width:20px; height:20px; background:url(images/alert-delete.png) no-repeat center center; vertical-align:middle; float:right; cursor:pointer; margin:5px auto auto auto;}

 HTLM代码:

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>kingwell</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<div style=" padding:50px">

	<div id="alertA">弹出框A测试 Click Me</div><br><br>
	<div id="alertB">弹出框B测试 Click Me</div>
	
</div>

<script type="text/javascript" src="../js/lib/KW.js"></script>
<script type="text/javascript">
/*----- Test AlertBox -----*/
WS.addEvent("alertA", "click", function () {
	alertBox("System Prompt", "<div class='strong'>Alert Test !按ESC键试试</div><br><br><input type='text'><br><br><br><br><button>Save</button><button>Cancel</button>");
	WS.addEvent("alert-close", "click", delAlert)
});

WS.addEvent("alertB", "click", function () {
	alertBox("Prompt", "<div class='strong a-c'>Are you sure you want to delete?</div>","prompt");
	WS.addEvent("alert-close", "click", delAlert)
});

</script>
</body>
<html>
 

 

 

0
2
分享到:
评论

相关推荐

    sweetalert弹出框

    -- 弹出框 --&gt; &lt;link rel="stylesheet" href="__PUBLIC__/css/sweetalert.css"&gt; &lt;!-- 弹出框 --&gt; &lt;script type="text/javascript" src="__PUBLIC__/wxparent/js/sweetalert-dev.js"&gt; swal({ title: "", text: res...

    alert弹出框

    首先,最基本的alert弹出框是JavaScript原生的`window.alert()`函数,它会显示一个包含指定文本的不可定制的对话框。然而,为了提供更丰富的用户体验和设计灵活性,开发者通常会选择使用更高级的方法。例如,使用...

    alert和confirm弹出框样式美化.zip

    标题“alert和confirm弹出框样式美化.zip”提示我们这个压缩包包含的是关于如何自定义和美化`alert`和`confirm`弹出框的内容,使它们更加符合网页的整体设计风格。 描述中提到,这个资源可以让我们自定义弹出框的...

    alert和confirm弹出框样式美化

    本教程将介绍如何通过自定义CSS和JavaScript来美化`alert`和`confirm`弹出框,实现更个性化的界面效果,而无需依赖浏览器的默认样式。 首先,我们不再直接使用`window.alert()`和`window.confirm()`方法,而是创建...

    alert及confirm弹出框样式,换不错

    `alert` 函数的基本语法是 `alert(message)`,它会弹出一个只有一个按钮的对话框,用户点击后,对话框关闭,程序继续执行。`message` 参数是向用户显示的文本字符串。 `confirm` 函数的语法是 `var result = ...

    html弹出框

    jQuery是一个流行的JavaScript库,它简化了DOM操作、事件处理以及动画效果,因此使用jQuery封装弹出框可以大大提高开发效率。 在描述中提到,你已经用jQuery实现了一个自定义的弹出框,并且只需引入相关的CSS和JS...

    sweetalert 手机弹出框

    -- 弹出框 --&gt; &lt;link rel="stylesheet" href="__PUBLIC__/css/sweetalert.css"&gt; &lt;!-- 弹出框 --&gt; &lt;script type="text/javascript" src="__PUBLIC__/wxparent/js/sweetalert-dev.js"&gt; swal({ title: "", text: res...

    弹出框zDialog

    1.代替window.open、window.alert、window.confirm;提供良好的用户体验; 2.水晶质感,设计细腻,外观漂亮; 3.兼容ie6/7/8、firefox2/3、Opera;弹出框在ie6下不会被select控件穿透; 4.无外部css文件,引用Dialog...

    JQUERY-window弹出框-组件v1.0

    “窗口”(window)在这里指的是模拟操作系统窗口的行为,比如弹出框可以被最大化,以占据整个浏览器视口,或者可以被最小化或恢复到原始大小。实现这些功能需要对CSS和JavaScript有深入理解,特别是涉及到窗口状态...

    让JavaScript的Alert弹出框失效的方法禁止弹出警告框

    在现代网络环境中,弹出广告、提示信息、警告框等可能会干扰用户的浏览体验,尤其是JavaScript弹出的Alert警告框,它们可以打断用户操作流程,有时还可能被用于网络钓鱼或恶意软件活动。因此,开发社区中逐渐出现了...

    重写window.alert方法

    5. **测试**:在自动化测试中,可能需要避免`alert`的弹出干扰测试流程,重写后可以控制是否显示。 需要注意的是,重写系统方法可能会对第三方库或未知代码产生影响,因此在实际项目中要谨慎使用。如果只是为了在...

    自定义alert提示框

    在IT行业中,自定义Alert提示框是一个常见的需求,特别是在开发用户界面时,为了提供更加个性化和符合品牌风格的用户体验。通常,系统自带的alert对话框样式单一,难以满足设计和功能上的扩展要求。本篇文章将深入...

    popup 弹出框 js

    本篇文章将深入探讨`popup`弹出框的实现方式、设计原则以及JavaScript在创建弹出框中的作用。 一、JavaScript与Popup弹出框 JavaScript(JS)是网页开发中的重要脚本语言,它可以动态地改变网页内容和行为,包括...

    JS版的弹出框,按钮事件的弹出框和链接事件的弹出框

    本篇文章将详细讲解如何创建和使用JavaScript中的不同类型的弹出框,包括按钮事件触发的弹出框和链接事件触发的弹出框。 一、基本弹出框:alert(), confirm(), prompt() 1. alert():警告对话框 `alert()` 函数...

    网页自动弹出框

    在JavaScript中,我们可以使用`window.alert()`、`window.confirm()`或`window.prompt()`方法来创建弹出框。`alert()`用于显示警告对话框,一般只包含一个“确定”按钮;`confirm()`则会显示一个确认对话框,带有...

    安卓-三种类型的弹出框

    本文将深入探讨三种主要的弹出框类型:AlertDialog、PopupWindow以及基于Activity的自定义弹出框。 首先,我们来谈谈**第一种类型的弹出框:AlertDialog**。AlertDialog是安卓系统内置的一种对话框,提供了标准的...

    详解Android 全局弹出对话框SYSTEM_ALERT_WINDOW权限

    然而,方案一存在一个问题:在某些设备(如小米手机)上,系统默认可能禁止了此类弹出框。为了解决这个问题,可以采用方案二,即通过启动一个主题设置为`Theme.Dialog`的Activity来模拟对话框效果,如下: ```java ...

    asp.net弹出框示例代码

    1. **JavaScript** 和 **jQuery**:通过调用浏览器的JavaScript API,例如`window.alert()`,`window.confirm()`和`window.prompt()`,可以实现基本的弹出框功能。更复杂的对话框可以通过jQuery UI的Dialog插件或...

    自定义window.alert对话框JS代码

    而“经典弹出对话框”则暗示了这个自定义对话框可能沿用了传统对话框的基本结构,如一个中心显示的提示信息,以及一个或多个操作选项。 在提供的压缩包文件中,有两个主要文件: 1. `main.html`:这是HTML文件,它...

    JS实现自动消息弹出框

    在JavaScript(JS)中,实现自动消息弹出框是一项常见的任务,这通常涉及到网页的交互性和用户体验。消息弹出框可以用于提示用户信息、警告、确认操作或接收用户输入。以下是一个详细的步骤来阐述如何使用JavaScript...

Global site tag (gtag.js) - Google Analytics