<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<link href="test.css" media="screen" rel="stylesheet" type="text/css" />
<title>IE-firfox-弹出 背景 拖动层</title>
<script type="text/javascript">
//获取滚动条的高度
function getPageScroll(){
var xScroll,yScroll;
if (self.pageYOffset) {
yScroll = self.pageYOffset;
xScroll = self.pageXOffset;
} else if (document.documentElement && document.documentElement.scrollTop){
yScroll = document.documentElement.scrollTop;
}else if (document.documentElement && document.documentElement.scrollLeft){
xScroll = document.documentElement.scrollLeft;
} else if (document.body) {
yScroll = document.body.scrollTop;
xScroll = document.body.scrollLeft;
}
arrayPageScroll = new Array(xScroll,yScroll)
return arrayPageScroll;
}
//获取页面实际大小
function getPageSize(){
var xScroll,yScroll;
if (window.innerHeight && window.scrollMaxY){
xScroll = document.body.scrollWidth;
yScroll = window.innerHeight + window.scrollMaxY;
} else if (document.body.scrollHeight > document.body.offsetHeight){
sScroll = document.body.scrollWidth;
yScroll = document.body.scrollHeight;
} else {
xScroll = document.body.offsetWidth;
yScroll = document.body.offsetHeight;
}
var windowWidth,windowHeight;
//var pageHeight,pageWidth;
if (self.innerHeight) {
windowWidth = self.innerWidth;
windowHeight = self.innerHeight;
} else if (document.documentElement && document.documentElement.clientHeight) {
windowWidth = document.documentElement.clientWidth;
windowHeight = document.documentElement.clientHeight;
} else if (document.body) {
windowWidth = document.body.clientWidth;
windowHeight = document.body.clientHeight;
}
var pageWidth,pageHeight
if(yScroll < windowHeight){
pageHeight = windowHeight;
} else {
pageHeight = yScroll;
}
if(xScroll < windowWidth) {
pageWidth = windowWidth;
} else {
pageWidth = xScroll;
}
arrayPageSize = new Array(pageWidth,pageHeight,windowWidth,windowHeight)
return arrayPageSize;
}
//弹出层
function openLayer(objId,conId,w,h){
var arrayPageSize = getPageSize();//调用getPageSize()函数
var arrayPageScroll = getPageScroll();//调用getPageScroll()函数
if (!document.getElementById("popupAddr")){
//创建弹出内容层
var popupDiv = document.createElement("div");
//给这个元素设置属性与样式
popupDiv.setAttribute("id","popupAddr")
popupDiv.style.position = "absolute";
popupDiv.style.zIndex = 99;
popupDiv.style.width = w + "px";
popupDiv.style.height = h + "px";
//创建弹出背景层
var bodyBack = document.createElement("div");
bodyBack.setAttribute("id","bodybg")
bodyBack.style.position = "absolute";
bodyBack.style.width = "100%";
bodyBack.style.height = (arrayPageSize[1] + 35 + 'px');
bodyBack.style.zIndex = 98;
bodyBack.style.top = 0;
bodyBack.style.left = 0;
bodyBack.style.filter = "alpha(opacity=80)";
bodyBack.style.opacity = 0.8;
bodyBack.style.background = "#ddf";
//实现弹出(插入到目标元素之后)
var mybody = document.getElementById(objId);
insertAfter(popupDiv,mybody);//执行函数insertAfter()
insertAfter(bodyBack,mybody);//执行函数insertAfter()
}
//显示背景层
document.getElementById("bodybg").style.display = "";
//显示内容层
var popObj=document.getElementById("popupAddr")
popObj.innerHTML = document.getElementById(conId).innerHTML;
popObj.style.display = "";
//让弹出层在页面中垂直左右居中(个性)
var arrayConSize=getConSize(conId,w,h)
if(arrayPageSize[3] < arrayConSize[1])
popObj.style.top = 0 + 'px';
else
popObj.style.top = arrayPageScroll[1] + (arrayPageSize[3] - arrayConSize[1]) / 2 + 'px';
if(arrayPageSize[0] < arrayConSize[0])
popObj.style.left = 0 + 'px';
else
popObj.style.left = (arrayPageSize[0] - arrayConSize[0]) / 2 + 'px';
}
//获取内容层内容原始尺寸
function getConSize(conId,w,h){
var conObj=document.getElementById(conId)
conObj.style.position = "absolute";
conObj.style.left=-1000+"px";
conObj.style.display="";
conObj.style.width= w + "px";
conObj.style.height= h + "px";
var arrayConSize=[0,0];
arrayConSize[0]=conObj.offsetWidth;
arrayConSize[1]=conObj.offsetHeight;
conObj.style.display="none";
return arrayConSize;
}
//插入
function insertAfter(newElement,targetElement){
var parent = targetElement.parentNode;
if(parent.lastChild == targetElement){
parent.appendChild(newElement);
}
else{
parent.insertBefore(newElement,targetElement.nextSibling);
}
}
//关闭弹出层
function closeLayer(){
document.getElementById("popupAddr").style.display = "none";
document.getElementById("bodybg").style.display = "none";
return false;
}
//拖拽
//对“拖动点”定义:onMousedown="StartDrag(event)"即可
var move=false,_X,_Y;
var isIE = document.all ? true : false;
function StartDrag(e){ //定义准备拖拽的函数 按下鼠标onMousedown
var parentwin=document.getElementById("popupAddr");
var d = document;
var e = e ? e : event;
if(isIE){parentwin.setCapture(); //对当前对象的鼠标动作进行跟踪
}else{
window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);
}
move=true;
//获取鼠标相对内容层坐标
_X=parentwin.offsetLeft-e.clientX
_Y=parentwin.offsetTop-e.clientY
var arrayPageSize = getPageSize();//调用getPageSize()函数
var arrayPageScroll = getPageScroll();//调用getPageScroll()函数
d.onmousemove = function(e){//定义拖拽函数 鼠标放上 拖动onMousemove
var e = e ? e : Event;
if(move){
var parentwin=document.getElementById("popupAddr");
var x = e.clientX+_X
var y = e.clientY+_Y
if (x<=0)
x = 0
if (y<=0)
y = 0
parentwin.style.left= (x)+ "px";;
parentwin.style.top= (y)+ "px";;
}
}
d.onmouseup = function (){//定义停止拖拽函数 松开鼠标 onMouseup
//停止对当前对象的鼠标跟踪
if(isIE){parentwin.releaseCapture();}
else{window.releaseEvents(Event.MOUSEMOVE|Event.MOUSEUP);}
move=false;
}
}
</script>
</head>
<body>
<input name="Input" id="test3" value="弹出层" type="button" onclick="openLayer('test3','test','400','300')" />
<div id="test" style="display:none">
<div id="contain" class="contain">
<div id="dtit" class="dlgtit" onMousedown="StartDrag(event)">
<div id="tl"></div>
<div id="tc"><span>弹出普通带遮罩层的窗口-标题</span></div>
<div id="tr"></div>
<div id="xbtn" onclick="closeLayer();" onMouseover="this.style.backgroundPosition = '0 -19px';" onMouseout="this.style.backgroundPosition = '0 0';"></div>
</div>
<div id="dinner" class="dlginner" style="height: 238px;">
<div id="throbber" style="position:absolute;visibility:hidden;">正在加载窗口内容,请稍等....< /div>
</div>
<div id="dfoot" class="dlgfoot">
<div id="bl"></div>
<div id="bc"></div>
<div id="br"></div>
<div id="cbtn" onclick="closeLayer();" onMouseover="this.style.backgroundPosition = '0 -21px';" onMouseout="this.style.backgroundPosition = '0 0';"><span>取 消</span></div>
<div id="obtn" onclick="alert('确定事件!');" onMouseover="this.style.backgroundPosition = '0 -21px';" onMouseout="this.style.backgroundPosition = '0 0';"><span>确 定</span></div>
</div>
</div>
</div>
</body>
</html>
分享到:
相关推荐
1. **遮罩效果**:遮罩层是在弹出窗口后面添加一个半透明的背景层,以突出显示弹出窗口并防止用户与页面其他部分互动。实现这一效果通常涉及到CSS的透明度和定位属性,以及JavaScript来动态调整遮罩层的大小和显示。...
遮罩层通常设置为全屏大小,具有一定的透明度,以达到半透明效果,而弹出层则位于页面中央,用于展示具体内容。 要实现这种效果,我们需要掌握以下技术点: 1. **CSS样式**:使用CSS来定义`div`的样式,包括位置、...
本文将详细介绍如何使用JS实现这种遮罩层效果,并探讨其在IE、Firefox以及jQuery环境下的应用。 首先,让我们理解遮罩层的基本原理。遮罩层通常由两个主要部分组成:遮罩元素和目标元素。遮罩元素是覆盖在页面上的...
描述中提到"兼容IE\FF\google等主流浏览器",这意味着这个遮罩层解决方案经过优化,可以在Internet Explorer、Firefox和Chrome这些广泛使用的浏览器上正常工作。对于开发者来说,跨浏览器兼容性是至关重要的,因为...
全屏遮罩是一种半透明的覆盖层,它覆盖整个网页,让用户知道当前页面已处于非交互状态。遮罩的颜色通常是淡灰色或黑色,具有一定的透明度,使得用户能够隐约看到页面背景,但无法直接与页面内容进行交互。这样做是...
遮罩层是一种常见的网页设计技术,主要用于在页面上覆盖一层半透明或不透明的层,以此来突出显示某个特定元素或者区域。这种技术广泛应用于模态窗口、弹出框等场景。 ##### 1.2 DIV遮罩层的基本原理 在Web开发中,...
2. **页面加载中遮罩层**:遮罩层通常是一个半透明的div,覆盖在网页上,用于提示用户页面正在加载或处理中,避免用户在数据加载完成前进行不必要的操作。它可以提供更好的用户体验,让用户知道系统正在进行后台工作...
本篇文章将详细介绍如何使用CSS和div元素来创建一个兼容IE6到IE9以及Firefox的遮罩层。 首先,我们需要在HTML中定义两个div元素。一个是`#black_overlay`,它作为遮罩层,覆盖整个页面,通常具有半透明黑色背景;另...
在IT行业中,遮罩层(Mask Layer)是一种常见的前端网页设计技术,用于在页面上创建一个半透明或全透明的覆盖层,以突出显示特定内容或执行特定操作时,阻止用户与页面其他部分的交互。这个名为“精典源码之遮罩层...
这一技术结合了HTML的`<div>`元素、CSS样式以及JavaScript/jQuery的动态效果,以实现具有半透明遮罩层的弹出层效果。下面将详细讲解这个知识点。 1. **HTML `<div>`元素**: `<div>`是HTML中的一个块级元素,用于...
本文将深入探讨如何使用JavaScript实现一个兼容IE和Firefox浏览器的弹出遮罩提示框,并且会涉及到一些很酷的效果。 首先,我们需要理解“遮罩”和“提示框”的概念。遮罩通常是一个半透明的层,覆盖在网页的主内容...
本文将详细讲解如何用CSS实现`<div>`的半透明效果,并确保兼容主流浏览器。 首先,让我们看看提供的代码片段: ```html <div style="filter: alpha(opacity=50);-moz-opacity: 0.5;opacity: 0.5;width: 100%;"> ...
1. `mask.gif`:这可能是一个用于对话框背景的半透明图片,通常用来创建遮罩效果,使得用户不能直接与对话框背后的页面元素互动。 2. `mask.html`:这是一个HTML文件,可能是对话框的示例或者测试页面,展示如何在...
还可以通过设置`opacity`和`background-color`实现半透明遮罩效果,增强用户体验。 2. JavaScript/jQuery:JavaScript可以监听用户交互,如点击事件,然后动态修改`div`的样式以展示或隐藏弹出层。例如,使用`...
在JavaScript编程中,创建一个兼容Firefox(FF)和Internet Explorer(IE)的遮罩层是一项常见的需求,特别是在构建交互式Web应用或者需要弹出框、提示信息时。标题中的"超级爽的 js 遮罩层 谦容 FF IE 支持拖动...
这样,当用户将鼠标悬停在图片上时,就会看到一个半透明的遮罩层淡入,同时文字也会淡入显示。这个效果在Chrome、Firefox、Safari、Edge等主流浏览器中都应能正常工作。 为了确保兼容性,可以使用jQuery的`$....
当用户将鼠标指针悬停在图片上时,会覆盖一层半透明的遮罩,同时显示相关的文字信息。这种效果在产品展示、图片预览等场景中尤为常见,能够增加网站的互动性和专业感。 实现这一效果主要依赖于JavaScript库jQuery,...
2. **遮罩层**:遮罩层是覆盖在对话框下方的半透明层,用于突出显示对话框并阻止用户对背景内容的操作。实现遮罩层,我们可以创建一个全屏的div元素,设置合适的透明度和背景颜色,然后将其定位在页面底部。当对话框...