交互设计中心-72色

交互设计中心 | 用户体验 | 优化

用DIV模拟弹出窗口--窗体滚动跟随

2008年4月24日 | 分类:jquery/javascript | 评论:0 | 引用:0 | 浏览: | Tags:IE与Firefox兼容  javascript  js  div  
复制以下代码直接写到记事本里保存成html文件即可看到效果 IE6、IE7、FF2兼容,其他浏览器未测试
<!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" lang="zh-CN"><head>
<title>72色-http://www.72color.com/</title>
<script>
function getPosition() {
      var top    = document.documentElement.scrollTop;
      var left   = document.documentElement.scrollLeft;
      var height = document.documentElement.clientHeight;
      var width  = document.documentElement.clientWidth;
      return {top:top,left:left,height:height,width:width};
}

function showPop(){
	var width  = 300;  //弹出框的宽度
	var height = 160;  //弹出框的高度
	var obj    = document.getElementById("pop");
	
	obj.style.display  = "block";
	obj.style.position = "absolute";
	obj.style.zindex   = "999";
	obj.style.width    = width + "px";
	obj.style.height   = height + "px";
	
	var Position = getPosition();
	leftadd = (Position.width-width)/2;
	topadd  = (Position.height-height)/2;
	obj.style.top  = (Position.top  + topadd)  + "px";
	obj.style.left = (Position.left + leftadd) + "px";
	
	window.onscroll = function (){
		var Position   = getPosition();
		obj.style.top  = (Position.top  + topadd)  +"px";
		obj.style.left = (Position.left + leftadd) +"px";
	};
}

function hidePop(){
	document.getElementById("pop").style.display = "none";
}
</script>
</head>
<body>
丁学--博客园--http://www.cnblogs.com/dingxue
<div id="pop" style="border:1px solid #CCC;display:none;">test<br><a href="javascript:hidePop();" mce_href="javascript:hidePop();">hide</a></div>
<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 href="javascript:showPop()" mce_href="javascript:showPop()">show</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>
</body>
</html>
Share
« CSS兼容问题:inline-block 属性运用去掉table的border默认属性的3维效果 »



◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。