« CSS兼容问题:inline-block 属性运用去掉table的border默认属性的3维效果 »

用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>丁学-博客园-http://www.cnblogs.com/dingxue</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>

« CSS兼容问题:inline-block 属性运用去掉table的border默认属性的3维效果 »

发表评论:

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

Search

最近发表

最新评论及回复

Powered By Z-Blog 1.8 Arwen Build 81206 Code detection by Codefense  theme by BokeZhuti

Copyright 72color.com WebSite. Some Rights Reserved.
admin 沪ICP备09011764号