JS制作有遮罩层的模式对话框
2011-07-14 21:15
411 查看
1遮罩层其实就是一个覆盖全界面的半透明的DIV,并处理zIndex使他浮于其他元素之上,是用户不能点击下边的元素,或者说点击没有反应。
2在遮罩层上方在弹出一个层,由于遮罩层挡住了其他所有元素,用户只能点击弹出层,制造出模式窗口的假象。
3JS代码
function openDiv(newDivID)
{ var newMaskID = "mask"; //遮罩层id var newMaskWidth =document.body.scrollWidth;//遮罩层宽度 var newMaskHeight =document.body.scrollHeight;//遮罩层高度 //mask遮罩层 var newMask = document.createElement("div");//创建遮罩层 newMask.id = newMaskID;//设置遮罩层id newMask.style.position = "absolute";//遮罩层位置 newMask.style.zIndex = "1";//遮罩层zIndex newMask.style.width = newMaskWidth + "px";//设置遮罩层宽度 newMask.style.height = newMaskHeight + "px";//设置遮罩层高度 newMask.style.top = "0px";//设置遮罩层于上边距离 newMask.style.left = "0px";//设置遮罩层左边距离 newMask.style.background = "red";//#33393C//遮罩层背景色 newMask.style.filter = "alpha(opacity=40)";//遮罩层透明度IE newMask.style.opacity = "0.40";//遮罩层透明度FF document.body.appendChild(newMask);//遮罩层添加到DOM中 //新弹出层 var newDivWidth = 400;//新弹出层宽度 var newDivHeight = 200;//新弹出层高度 var newDiv = document.createElement("div");//创建新弹出层 newDiv.id = newDivID;//设置新弹出层ID newDiv.style.position = "absolute";//新弹出层位置 newDiv.style.zIndex = "9999";//新弹出层zIndex newDiv.style.width = newDivWidth + "px";//新弹出层宽度 newDiv.style.height = newDivHeight + "px";//新弹出层高度 var newDivtop=(document.body.scrollTop + document.body.clientHeight/2 - newDivHeight/2) ;//新弹出层距离上边距离 var newDivleft=(document.body.scrollLeft + document.body.clientWidth/2 - newDivWidth/2);//新弹出层距离左边距离 newDiv.style.top = newDivtop+ "px";//新弹出层距离上边距离 newDiv.style.left = newDivleft + "px";//新弹出层距离左边距离 newDiv.style.background = "#EFEFEF";//新弹出层背景色 newDiv.style.border = "1px solid #860001";///新弹出层边框样式 newDiv.style.padding = "5px";//新弹出层 newDiv.innerHTML = "content;content";//新弹出层内容 document.body.appendChild(newDiv);//新弹出层添加到DOM中 //弹出层滚动居中 function newDivCenter() { newDiv.style.top = (document.body.scrollTop + document.body.clientHeight/2 - newDivHeight/2) + "px"; newDiv.style.left = (document.body.scrollLeft + document.body.clientWidth/2 - newDivWidth/2) + "px"; } if(document.all)//处理滚动事件,使弹出层始终居中 { window.attachEvent("onscroll",newDivCenter); } else { window.addEventListener('scroll',newDivCenter,false); } //关闭新图层和mask遮罩层 var newA = document.createElement("span"); newA.href = "#"; newA.style.position = "absolute";//span位置 newA.style.left=350+ "px"; newA.innerHTML = "Close"; newA.onclick = function()//处理关闭事件 { if(document.all) { window.detachEvent("onscroll",newDivCenter); } else { window.removeEventListener('scroll',newDivCenter,false); } document.body.removeChild(newMask);//移除遮罩层 document.body.removeChild(newDiv);////移除弹出框 return false; } newDiv.appendChild(newA);//添加关闭span }
4测试代码
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
</HEAD>
<BODY>
<a onclick="openDiv('newDiv');" style="cursor:pointer">TestOpenDiv</a>
<br /><br /><br /><br /><br /><br />
<br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br />
<br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br />
<br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br />
<br /><br /><br /><br /><br /><br />
<a onclick="openDiv('newDiv');" style="cursor:pointer">TestOpenDiv</a>
</BODY>
</HTML>
今天算懂了弹出层遮罩了,其实吧,很简单,z-index很重要,设置时要注意
2在遮罩层上方在弹出一个层,由于遮罩层挡住了其他所有元素,用户只能点击弹出层,制造出模式窗口的假象。
3JS代码
function openDiv(newDivID)
{ var newMaskID = "mask"; //遮罩层id var newMaskWidth =document.body.scrollWidth;//遮罩层宽度 var newMaskHeight =document.body.scrollHeight;//遮罩层高度 //mask遮罩层 var newMask = document.createElement("div");//创建遮罩层 newMask.id = newMaskID;//设置遮罩层id newMask.style.position = "absolute";//遮罩层位置 newMask.style.zIndex = "1";//遮罩层zIndex newMask.style.width = newMaskWidth + "px";//设置遮罩层宽度 newMask.style.height = newMaskHeight + "px";//设置遮罩层高度 newMask.style.top = "0px";//设置遮罩层于上边距离 newMask.style.left = "0px";//设置遮罩层左边距离 newMask.style.background = "red";//#33393C//遮罩层背景色 newMask.style.filter = "alpha(opacity=40)";//遮罩层透明度IE newMask.style.opacity = "0.40";//遮罩层透明度FF document.body.appendChild(newMask);//遮罩层添加到DOM中 //新弹出层 var newDivWidth = 400;//新弹出层宽度 var newDivHeight = 200;//新弹出层高度 var newDiv = document.createElement("div");//创建新弹出层 newDiv.id = newDivID;//设置新弹出层ID newDiv.style.position = "absolute";//新弹出层位置 newDiv.style.zIndex = "9999";//新弹出层zIndex newDiv.style.width = newDivWidth + "px";//新弹出层宽度 newDiv.style.height = newDivHeight + "px";//新弹出层高度 var newDivtop=(document.body.scrollTop + document.body.clientHeight/2 - newDivHeight/2) ;//新弹出层距离上边距离 var newDivleft=(document.body.scrollLeft + document.body.clientWidth/2 - newDivWidth/2);//新弹出层距离左边距离 newDiv.style.top = newDivtop+ "px";//新弹出层距离上边距离 newDiv.style.left = newDivleft + "px";//新弹出层距离左边距离 newDiv.style.background = "#EFEFEF";//新弹出层背景色 newDiv.style.border = "1px solid #860001";///新弹出层边框样式 newDiv.style.padding = "5px";//新弹出层 newDiv.innerHTML = "content;content";//新弹出层内容 document.body.appendChild(newDiv);//新弹出层添加到DOM中 //弹出层滚动居中 function newDivCenter() { newDiv.style.top = (document.body.scrollTop + document.body.clientHeight/2 - newDivHeight/2) + "px"; newDiv.style.left = (document.body.scrollLeft + document.body.clientWidth/2 - newDivWidth/2) + "px"; } if(document.all)//处理滚动事件,使弹出层始终居中 { window.attachEvent("onscroll",newDivCenter); } else { window.addEventListener('scroll',newDivCenter,false); } //关闭新图层和mask遮罩层 var newA = document.createElement("span"); newA.href = "#"; newA.style.position = "absolute";//span位置 newA.style.left=350+ "px"; newA.innerHTML = "Close"; newA.onclick = function()//处理关闭事件 { if(document.all) { window.detachEvent("onscroll",newDivCenter); } else { window.removeEventListener('scroll',newDivCenter,false); } document.body.removeChild(newMask);//移除遮罩层 document.body.removeChild(newDiv);////移除弹出框 return false; } newDiv.appendChild(newA);//添加关闭span }
4测试代码
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
</HEAD>
<BODY>
<a onclick="openDiv('newDiv');" style="cursor:pointer">TestOpenDiv</a>
<br /><br /><br /><br /><br /><br />
<br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br />
<br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br />
<br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br />
<br /><br /><br /><br /><br /><br />
<a onclick="openDiv('newDiv');" style="cursor:pointer">TestOpenDiv</a>
</BODY>
</HTML>
今天算懂了弹出层遮罩了,其实吧,很简单,z-index很重要,设置时要注意
相关文章推荐
- JS制作有遮罩层的模式对话框 .
- js 弹出对话框(遮罩)透明,可拖动的简单实例
- js弹出对话框,遮罩效果,
- js弹出对话框,遮罩效果,
- 【转】用JS实现弹出模式对话框,实现页面传值
- js遮罩效果制作弹出注册界面效果
- JS打开模式对话框
- JS制作有遮罩层的模式对话框
- angularjs+bootstrap+ngDialog实现模式对话框
- Js制作简单弹出层DIV在页面居中 中间显示遮罩的具体方法
- 网页中常用的JS 检证功能及打开模式对话框
- JS制作有遮罩层的模式对话框
- iw14.0.50来了,终于可以直接在地址栏输入url打开iw功能页面了;可以自由使用EasyUI等js框架了;显示模式对话框也不再七绕八绕惹人烦了;
- Vegas轨道合成模式如何制作遮罩效果?
- js 模式窗口(模式对话框和非模式对话框)的使用介绍
- js 模式窗口(模式对话框和非模式对话框)的使用介绍
- js弹出模式对话框,并接收回传值的方法
- JS弹出可移动的DIV对话框透明遮罩效果
- JS实现制作弹出小窗口并获取参数值2(js弹出对话框集合)
- 模式对话框和js操作gridview (Datagrid)