JS制作有遮罩层的模式对话框
来源:互联网 发布:淘宝司法拍卖车攻略 编辑:程序博客网 时间:2024/06/06 01:37
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模式对话框
- JS打开模式对话框
- 两级对话框的制作
- 自定义对话框的制作
- 对话框的制作
- blackberry弹出对话框的制作
- 模式对话框与非模式的对话框
- 日期对话框的JS
- js对话框的总结
- js对话框的总结
- 自定义的JS对话框
- SQL中DISTINCT 后面有多个字段, 如何操作
- [VC++]如何得到桌面窗口的句柄(桌面图标)
- php 测试连接mysql
- dom4j 写简单XML文件
- gridview中获取主键的值
- JS制作有遮罩层的模式对话框
- 权限问题引起的 asp.net Excel 报错
- JDBC 连接Oracle 技巧
- 用Apache Commons Betwixt2 在XML与Java对象之间相互转换
- android Binder机制深入浅出
- 保护模式保护二字的理解(部分取自于渊)
- C#连接数据库的三种方法
- 手动绑定数据到GridView并实现编辑,删除,取消···
- vSphere 5 产品发布会