首页 > 其他分享 >自定义信息提示框dialog.js

自定义信息提示框dialog.js

时间:2023-05-11 11:25:15浏览次数:54  
标签:document 自定义 dialogContent null owner dialog var 提示框

var owner;
function getOwner() {
	if (owner)
		return owner;
	var owner = window;
	try {
		if (top.document.domain == window.document.domain) {
			if(top.length > 1)
			    owner2=top[0];
		    else
				owner = top;
		}
	} catch (ex) {
		while (owner.parent) {
			try {
				if (owner.parent.document.domain == document.domain) {
					owner = owner.parent;
				}
			} catch (e) {
				break;
			};
		};
	};
	window.owner = owner;
	return owner;
}

Dialog = mySoft.ui.Dialog = function Dialog(title, x, y, width, height) {// dialog为窗口名称
	var object = this;
	var hwnd = this.Hwnd = parseInt(Math.random() * 1000000000000);
	var owner = getOwner();

	this.Title = title ? title : "无标题";
	this.Width = width ? width : 300;
	this.Height = height;
	this.X = x ? x : $getDocument().scrollLeft
			+ ($getDocument().clientWidth - this.Width) / 2;
	this.Y = y ? y : $getDocument().scrollTop
			+ ($getDocument().clientHeight - this.Height) / 4;;
	owner.window.zIndex = owner.window.zIndex ? owner.window.zIndex + 2 : 9999;
	this.zIndex = owner.window.zIndex;

	this.Show = function() {
		if (document.getElementById("DialogMask" + hwnd)) {
			document.getElementById("DialogMask" + hwnd).style.display = "block";
		};
		document.getElementById("Dialog" + hwnd).style.display = "block";
	};

	this.Hide = function() {
		if (document.getElementById("DialogMask" + hwnd)) {
			document.getElementById("DialogMask" + hwnd).style.display = "none";
		};
		document.getElementById("Dialog" + hwnd).style.display = "none";
		document.getElementById("Dialog" + hwnd).oncontextmenu = function() {
			return false
		};
	};

	this.Dispose = function() {
		try {
			var dialog = document.getElementById("Dialog" + hwnd);
			if (!dialog)
				return;
			var dialogMask = document.getElementById("DialogMask" + hwnd);
			var dialogContent = document.getElementById("DialogContent" + hwnd);
			if (dialogMask) {
				dialogMask.parentNode.removeChild(dialogMask);
				delete dialogMask;
				dialogMask = null;
			}
			try {
				var iframe = dialogContent.getElementsByTagName("iframe")[0];
				if (iframe) {
					iframe.contentWindow.document.open();
					iframe.contentWindow.document.clear();
					iframe.contentWindow.document.close();
					iframe.parentNode.removeChild(iframe);
				}
			} catch (ex) {

			};
			dialog.innerHTML = "";
			dialog.parentNode.removeChild(dialog);
			delete dialog;
			dialog = null;
			delete object;
			object = null;
			if (window.CollectGarbage)
				CollectGarbage();
		} catch (ex) {
		};
	};

	this.Close = function() {
		this.Dispose();
	};
	this.getContentWindow = function() {
		var dialogContent = document.getElementById("DialogContent" + hwnd);
		var iframe = dialogContent.getElementsByTagName("iframe")[0];
		return iframe.contentWindow;
	};
	this.showModelessDialog = function() {
		var dialogMask = document.getElementById("DialogMask" + hwnd);
		if (!dialogMask) {
			dialogMask = document.createElement("div");
			dialogMask.className = "MaskLayer";
			dialogMask.id = "DialogMask" + hwnd;
			document.body.appendChild(dialogMask);
			dialogMask.style.zIndex = this.zIndex - 1;
			dialogMask.style.display = "block";
			dialogMask.onmousedown = function(e) {
				if (e) {
					event = e;
				}
				event.cancelBubble = true;
			};
			dialogMask.oncontextmenu = function() {
				return false
			};
		};
		dialogMask.style.display = "block";
		delete dialogMask;
		dialogMask = null;
		this.Show();
	};

	this.AddContent = function(element) {
		var dialogContent = document.getElementById("DialogContent" + hwnd);
		dialogContent.appendChild(element);
	};

	this.GetContent = function() {
		var dialogContent = document.getElementById("DialogContent" + hwnd);
		return dialogContent;
	};
	this.SetSize = function(width, height) {
		var dialog = document.getElementById("Dialog" + hwnd);
		dialog.style.width = width + "px";
		var dialogContent = document.getElementById("content" + hwnd);
		dialogContent.style.height = height + "px";
	}
	this.setTitle = function(title) {

	};

	var dialog = document.createElement("div");
	dialog.className = "Dialog";
	dialog.id = "Dialog" + hwnd;
	dialog.hwnd = hwnd;
	dialog.style.zIndex = this.zIndex;
	dialog.style.left = this.X + "px";
	dialog.style.top = this.Y + "px";
	dialog.style.width = this.Width + "px";
	document.body.appendChild(dialog);

	var dialogRange = document.createElement("div");// dialogRange 参数化
	dialogRange.className = "DialogRange";
	dialog.appendChild(dialogRange);

	var header = document.createElement("div");
	header.className = "DialogHeader";
	header.id = "DialogHeader" + hwnd;
	dialogRange.appendChild(header);
	header.ondblclick = function(e) {
		// object.Max();
	};

	var headerLeft = document.createElement("div");
	headerLeft.className = "DialogHeaderLeft";
	header.appendChild(headerLeft);

	var expandImage = document.createElement("div");
	headerLeft.appendChild(expandImage);
	expandImage.className = "DialogHeaderExpand";
	expandImage.setAttribute("State", "Expand");
	expandImage.onmouseover = function() {
		this.className = "DialogHeader" + this.getAttribute("State") + "Over";
	};
	expandImage.onmouseout = function() {
		this.className = "DialogHeader" + this.getAttribute("State");
	};
	expandImage.onmousedown = function(e) {
		var ev = window.event;
		if (e) {
			ev = e;
			ev.srcElement = e.target;
		};
		ev.cancelBubble = true;
		var dialogContent = document.getElementById("content" + hwnd);
		if (this.getAttribute("State") == "Expand") {
			this.title = "展开";
			this.setAttribute("State", "Collapse");
			dialogContent.style.display = "none";
		} else {
			this.title = "折叠";
			this.setAttribute("State", "Expand");
			dialogContent.style.display = "block";
		};
		delete dialogContent;
		dialogContent = null;
	};
	var headerCenter = document.createElement("div");
	headerCenter.className = "DialogHeaderCenter";
	headerCenter.innerHTML = this.Title;
	header.appendChild(headerCenter);

	var headerRight = document.createElement("div");
	headerRight.className = "DialogHeaderRight";
	header.appendChild(headerRight);

	var closeImage = document.createElement("div");
	closeImage.className = "DialogHeaderClose";
	closeImage.title = "关闭";
	closeImage.onmouseover = function() {
		this.className = "DialogHeaderCloseOver";
	};
	closeImage.onmouseout = function() {
		this.className = "DialogHeaderClose";
	};
	closeImage.onmousedown = function(e) {
		var ev = window.event;
		if (e) {
			ev = e;
			ev.srcElement = e.target;
		};
		ev.cancelBubble = true;
		try {
			object.Close();
		} catch (ex) {
		}
	};
	headerRight.appendChild(closeImage);

	var content = document.createElement("div");
	content.id = "content" + hwnd;
	content.className = "DialogContent";
	dialogRange.appendChild(content);

	var footer = document.createElement("div");
	footer.className = "DialogFooter";
	dialogRange.appendChild(footer);

	if (this.Height) {
		content.style.height = this.Height - header.offsetHeight
				- footer.offsetHeight + "px";
		content.style.overflow = "auto";
	};

	var contentMask = document.createElement("div");
	contentMask.className = "DialogMask";
	contentMask.id = "contentMask" + hwnd;
	contentMask.style.display = "none";
	content.appendChild(contentMask);

	var dialogContent = document.createElement("div");
	dialogContent.id = "DialogContent" + hwnd;
	dialogContent.className = "DialogContent";
	dialogContent.style.height = "100%";
	// dialogContent.style.border="solid 1px #000000";
	content.appendChild(dialogContent);

	var iframe = document.createElement("iframe");
	iframe.className = "MaskIframe";
	dialog.appendChild(iframe);
	iframe.style.height = dialog.offsetHeight - 1 + "px";

	header.onmousedown = function(e) {
		var ev = window.event;
		if (e) {
			ev = e;
			ev.srcElement = e.target;
		};
		ev.cancelBubble = true;
		var contentMask = document.getElementById("contentMask" + hwnd);
		contentMask.style.display = "block";
		var dialog = this.parentNode.parentNode;
		var header = this;
		this.style.cursor = "move";
		var offsetX = ev.clientX - $GetLeft(dialog) - $getDocument().scrollLeft;
		var offsetY = ev.clientY - $GetTop(dialog) - $getDocument().scrollTop;
		document.onmousemove = function(e) {
			var ev = window.event;
			if (e) {
				ev = e;
				ev.srcElement = e.target;
			};
			window.getSelection
					? window.getSelection().removeAllRanges()
					: document.selection.empty();
			ev.cancelBubble = true;
			dialog.style.left = ev.clientX - offsetX + "px";
			dialog.style.top = ev.clientY - offsetY + "px";
		};
		document.onmouseup = function(e) {
			contentMask.style.display = "none";
			header.style.cursor = "";
			document.onmousemove = null;
			document.onmouseup = null;
			delete contentMask;
			contentMask = null;
			delete dialog;
			dialog = null;
			delete header;
			header = null;
		};
	};

	expandImage = null;
	delete expandImage;

	closeImage = null;
	delete closeImage;

	headerLeft = null;
	delete headerLeft;

	headerCenter = null;
	delete headerCenter;

	headerRight = null;
	delete headerRight;

	header = null;
	delete header;

	contentMask = null;
	delete contentMask;

	dialogContent = null;
	delete dialogContent;

	content = null;
	delete content;

	footer = null;
	delete footer;

	dialogRange = null;/* */
	delete dialogRange;
	dialog = null;/* */
	delete dialog;

	delete iframe;
	iframe = null;
	$addHandler(window, "unload", Function.createDelegate(this, this.Dispose));
};

$getWindow = mySoft.ui.Dialog.getWindow = function(name) {
	var owner = getOwner();
	return owner.window[name];
};

Dialog.showMsg = mySoft.ui.Dialog.showInfo = function(message, interval,
		onClose, isMark) {
	var interval = interval ? interval : 1000;
	var hwnd = parseInt(Math.random() * 1000000000000);
	var owner = getOwner();
	var dialogMask = null;

	if (isMark) {
		dialogMask = document.createElement("div");
		dialogMask.className = "MaskLayer";
		document.body.appendChild(dialogMask);
	}

	var dialog = document.createElement("div");
	dialog.className = "DialogMsg";
	dialog.hwnd = hwnd;
	dialog.innerHTML = message;

	document.body.appendChild(dialog);

	this.Dispose = function() {
		if (dialogMask) {
			dialogMask.parentNode.removeChild(dialogMask);
			dialogMask = null;
			delete dialogMask;
		}

		dialog.parentNode.removeChild(dialog);
		dialog = null;

		delete dialog;
		if (onClose) {
			onClose();
		};
	}

	$addHandler(window, "unload", Function.createDelegate(this, this.Dispose));

	window.setTimeout(Function.createDelegate(this, this.Dispose), interval);

}

function OpenDialog(url, title, x, y, width, height, win) {
	return openDialog("dialog", url, title, x, y, width, height, win);
}

function openDialog(name, url, title, x, y, width, height, win) {
	var owner = getOwner();
	if (win)
		owner = win;
	var dialog = new owner.Dialog(title, x, y, width, height);
	dialog.Close = function() {
		this.Dispose();
		if (owner.window[name]) {
			owner.window[name] = null;
		}
		delete dialog;
		dialog = null;
	};
	owner.window[name] = dialog;
	dialog.showModelessDialog();
	var dialogContent = dialog.GetContent();
	dialogContent.innerHTML = '<iframe frameborder="0" width="100%" height="100%"  src="'
			+ url
			+ '" onl oad="javascript:this.parentNode.childNodes[1].style.display=\'none\'"></iframe><div class="Loading"><div class="LoadingText">正在加载中...</div></div>';
	delete dialogContent;
	dialogContent = null;
	$addHandler(window, "unload", Function.createDelegate(dialog,
					dialog.Dispose));
	return dialog;
}

function OpenAjaxDialog(url, title, x, y, width, height) {
	var owner = getOwner();
	var dialog = new owner.Dialog(title, x, y, width, height);
	dialog.Close = function() {
		var scripts = top.document.getElementsByTagName("head")[0]
				.getElementsByTagName("script");
		var length = scripts.length;
		for (var s = length - 1; s > 0; s--) {
			var script = scripts[s];
			if ((script) && (script.getAttribute("id"))) {
				script.parentNode.removeChild(script);
			}
		}
		this.Dispose();
	};
	top.dialog = dialog;
	dialog.showModelessDialog();
	var dialogContent = dialog.GetContent();
	dialogContent.innerHTML = '<div class="Loading"></div>';
	var request = new $WebRequest(url, null, onl oad, onl oad);
	request.Start();
	$addHandler(window, "unload", function() {
				dialog.Close()
			});
	function onl oad(result) {
		top.$Eval(dialogContent, result);
	}
	return dialog;
}

Dialog.Alert = mySoft.ui.Dialog.Alert = function(title, message, onOk, width,
		height) {
	var owner = getOwner();
	var name = "AlertDialog";
	// 如果存在则不再弹出
	if (owner.window[name])
		return;
	var dialog = new owner.Dialog(title, null, null, width, null);

	owner.window[name] = dialog;
	dialog.showModelessDialog();
	var dialogContent = dialog.GetContent();

	var content = '<div class="DialogMessage"><div class="DialogMessageIcon"></div><div class="DialogMessageContent" align="center">'
			+ message + '</div></div>';
	content += '<div class="DialogActionBar" align="center"><input type="button" value=" 确定 " class="Button" onm ouseover="this.className=\'ButtonOver\'" onm ouseout=\"this.className=\'Button\'\" /></div>';
	dialogContent.innerHTML = content;
	// dialogContent.childNodes[0].style.height=dialogContent.clientHeight-dialogContent.childNodes[1].clientHeight+"px";
	var button = dialogContent.childNodes[1].childNodes[0];
	button.onclick = function() {
		dialog.Close();
		if (onOk) {
			onOk();
		}
	};
	dialog.Close = function() {
		this.Dispose();
		if (owner.window[name]) {
			owner.window[name] = null;
		}
		delete dialog;
		dialog = null;
	};

	button.focus();

	delete content;
	content = null;

	delete dialogContent;
	dialogContent = null;
	$addHandler(owner, "unload", Function
					.createDelegate(dialog, dialog.Dispose));
};

Dialog.Confirm = mySoft.ui.Dialog.Confirm = function(title, message, onOk,
		onCancel, width, height) {
	var owner = getOwner();
	var name = "ConfirmDialog";
	// 如果存在则不再弹出
	if (owner.window[name])
		return;
	var dialog = new owner.Dialog(title, null, null, width, null);
	dialog.Close = function() {
		this.Dispose();
		if (owner.window[name]) {
			owner.window[name] = null;
		}
		delete dialog;
		dialog = null;
	};
	owner.window[name] = dialog;
	dialog.showModelessDialog();
	var dialogContent = dialog.GetContent();

	var dialogContent = dialog.GetContent();
	var content = '<div class="DialogMessage" style="height:'
			+ (dialogContent.clientHeight - 35)
			+ 'px;"><div class="DialogMessageIcon"></div><div class="DialogMessageContent" align="center">'
			+ message + '</div></div>';
	content += '<div class="DialogActionBar" align="center"><input type="button" value=" 确定 " class="Button" onm ouseover="this.className=\'ButtonOver\'" onm ouseout=\"this.className=\'Button\'\" /><input type="button" value=" 取消 " class="Button" onm ouseover="this.className=\'ButtonOver\'" onm ouseout=\"this.className=\'Button\'\" /></div>';
	dialogContent.innerHTML = content;
	// dialogContent.childNodes[0].style.height=dialogContent.clientHeight-dialogContent.childNodes[1].clientHeight+"px";
	var button = dialogContent.childNodes[1].childNodes[0];
	button.onclick = function() {
		dialog.Close();
		if (onOk) {
			onOk();
		}
	};
	button.focus();
	button = dialogContent.childNodes[1].childNodes[1];
	button.onclick = function() {
		dialog.Close();
		if (onCancel) {
			onCancel();
		}
	}

	delete content;
	content = null;
	delete dialogContent;
	dialogContent = null;

	$addHandler(owner, "unload", Function
					.createDelegate(dialog, dialog.Dispose));
};

 

标签:document,自定义,dialogContent,null,owner,dialog,var,提示框
From: https://www.cnblogs.com/Marydon20170307/p/17390490.html

相关文章

  • uniapp自定义开发一个文本输入框
    开发component中的一个input标签一、在原来的模块上面创建一个新的类TestComponent1.新建TestComponent2.配置json文件二、uniapp准备工作1.在uniapp中写一下刚刚创建的输入框2.打包导出资源3.资源替换复制刚刚生成的本地资源文件夹到AndroidStudio项目中......
  • wordpress 为自定义类型文章新增自定义字段
    wordpress强大之处在于有很强的可自定义性,使得插件、主题的开发变得及其便利。就拿我们今天要说的自定义文章添加自定义字段来说,就很便捷。        比如我们要录入一个客户信息到wordpress中,那么需要的字段可不仅仅是什么标题、内容、摘要这么简单了,我们可能需要录入客户......
  • springboot+Prometheus+grafana 实现自定义监控(请求数、响应时间、JVM性能)
    自定义监控1.SpringBoot工程集成Micrometer1.1引入依赖1.2配置1.3监控jvm信息1.4创建自定义监控1.5添加具体业务代码监控2.集成Prometheus2.1安装2.2集成配置3.使用GrafanaDashboard展示监控项3.1安装grafana3.2配置prometheus数据源3.3增加jvm面板3.4配置业务接口监控面板......
  • 百度地图绘制地区的棱柱效果-定位-自定义点-文本标记-信息弹窗
    @目录百度地图webgl使用自定义地图样式地区镂面棱柱效果绘制点信息以及信息弹窗百度地图webgl使用在项目的index.html中引入<scripttype="text/javascript"src="//api.map.baidu.com/api?type=webgl&v=1.0&ak=你的AK秘钥"></script>注意,百度webgl的引入和百度地图的引入......
  • jquery ui dialog 遮拦 select的解决方法
    <scripttype="text/javascript"src="/js/jquery.bgiframe.min.js"></script>  1.    引用以上JS代码。 注意:jquery与jquery.bgiframe插件的对应版本  2.    JS代码加入红色部分         $("#dialog-editor").dialog({ bgiframe:true, ......
  • 直播app系统源码,dialogfragment设置底部没有和屏幕有间隔
    直播app系统源码,dialogfragment设置底部没有和屏幕有间隔 @Override  publicvoidonStart(){    super.onStart();    Windowwindow=getDialog().getWindow();    if(window!=null){      //设置window的背景色为透明色. ......
  • Android自定义Dialog(zhuang)
    Android自定义Dialog这段时间在做一个项目,需要使用到自定义Dialog,先在网上找了一下资料,发现还是有很多没有讲清楚的,在此给出一个Demo,一来可以方便广大码农,二来也可以方便自己,以备不时之需。。。先来一张图吧,很简单,只有一个Activity,当点击Button的时候就弹出这个自定义的Dialo......
  • 自定义 li 标签序列的样式
    第一步删除li标签的默认样式,取消::mark代理样式(默认样式)。第一步已经把默认样式取消了,自然没有了序号,使用CSS的counter()函数和counter-increment属性来自定义序列号。通过list-style-type:none删除li标签的默认样式在li标签样式中设置counter-increment:st......
  • SpringBoot+Redis+自定义注解实现接口防刷(限制不同接口单位时间内最大请求次数)
    场景SpringBoot搭建的项目需要对开放的接口进行防刷限制,不同接口指定多少秒内可以请求指定次数。比如下方限制接口一秒内最多请求一次。 注:博客:https://blog.csdn.net/badao_liumang_qizhi实现1、实现思路首先自定义注解,添加时间区间和最大请求次数字段。然后自定义......
  • 微信小程序 自定义组件 监听数据变化 出现异常 Maximum call stack size exceeded.
    代码调用处: 组件内部  本地调试无异常,发布之后出现此异常解决方法:监听属性steps的值变化时,调用处不能使用双向绑定,去掉steps的双向绑定即可,具体的原因未知(不知为啥本地调试不会抛异常) ......