JS模拟ALERT半透明背景,仿关机效果

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  2. <html xmlns="http://www.w3.org/1999/xhtml">  
  3. <head>  
  4. <title></title>  
  5. <style>  
  6. html,body{font-size:12px;margin:0px;height:100%;}  
  7. .mesWindow{border:#666 1px solid;background:#fff;}  
  8. .mesWindowTop{border-bottom:#eee 1px solid;margin-left:4px;padding:3px;font-weight:bold;text-align:left;font-size:12px;}  
  9. .mesWindowContent{margin:4px;font-size:12px;}  
  10. .mesWindow .close{height:15px;width:28px;border:none;cursor:pointer;text-decoration:underline;background:#fff}  
  11. </style>  
  12. <script>  
  13. var isIe=(document.all)?true:false;  
  14. //设置select的可见状态  
  15. function setSelectState(state)  
  16. {  
  17.  var objl=document.getElementsByTagName('select');  
  18.  for(var i=0;i<objl.length;i++)  
  19.  {  
  20.  objl[i].style.visibility=state;  
  21.  }  
  22. }  
  23. function mousePosition(ev)  
  24.  {  
  25.  if(ev.pageX || ev.pageY)  
  26.  {  
  27.  return {x:ev.pageX, y:ev.pageY};  
  28.  }  
  29.  return {  
  30.  x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,y:ev.clientY + document.body.scrollTop - document.body.clientTop  
  31.  };  
  32.  }  
  33. //弹出方法  
  34. function showMessageBox(wTitle,content,pos,wWidth)  
  35. {  
  36.  closeWindow();  
  37.  var bWidth=parseInt(document.documentElement.scrollWidth);  
  38.  var bHeight=parseInt(document.documentElement.scrollHeight);  
  39.  if(isIe){  
  40.  setSelectState('hidden');}  
  41.  var back=document.createElement("div");  
  42.  back.id="back";  
  43.  var styleStr="top:0px;left:0px;position:absolute;background:#666;width:"+bWidth+"px;height:"+bHeight+"px;";  
  44.  styleStr+=(isIe)?"filter:alpha(opacity=40);":"opacity:0.40;";  
  45.  back.style.cssText=styleStr;  
  46.  document.body.appendChild(back);  
  47.  var mesW=document.createElement("div");  
  48.  mesW.id="mesWindow";  
  49.  mesW.className="mesWindow";  
  50.  mesW.innerHTML="<div class='mesWindowTop'><table width='100%' height='100%'><tr><td>"+wTitle+"</td><td style='width:1px;'><input type='button' onclick='closeWindow();' title='关闭窗口' class='close' value='关闭' /></td></tr></table></div><div class='mesWindowContent' id='mesWindowContent'>"+content+"</div><div class='mesWindowBottom'></div>";  
  51.   
  52.  styleStr="left:"+(((pos.x-wWidth)>0)?(pos.x-wWidth):pos.x)+"px;top:"+(pos.y)+"px;position:absolute;width:"+wWidth+"px;";  
  53.  mesW.style.cssText=styleStr;  
  54.  document.body.appendChild(mesW);  
  55. }  
  56.  function showBackground(obj,endInt)  
  57. {  
  58.  obj.filters.alpha.opacity+=1;  
  59.  if(obj.filters.alpha.opacity<endInt)  
  60.  {  
  61.  setTimeout(function(){showBackground(obj,endInt)},8);  
  62.  }  
  63. }  
  64. //关闭窗口  
  65. function closeWindow()  
  66. {  
  67.  if(document.getElementById('back')!=null)  
  68.  {  
  69.  document.getElementById('back').parentNode.removeChild(document.getElementById('back'));  
  70.  }  
  71.  if(document.getElementById('mesWindow')!=null)  
  72.  {  
  73.  document.getElementById('mesWindow').parentNode.removeChild(document.getElementById('mesWindow'));  
  74.  }  
  75.   
  76.  if(isIe){  
  77.  setSelectState('');}  
  78. }  
  79. //测试弹出  
  80. function testMessageBox(ev)  
  81. {  
  82.  var objPos = mousePosition(ev);  
  83.  messContent="<div style='padding:20px 0 20px 0;text-align:center'>消息正文</div>";  
  84.  showMessageBox('窗口标题',messContent,objPos,350);  
  85. }  
  86. </script>  
  87. </head>  
  88. <body>  
  89. <div style="padding:20px">  
  90. <div style="text-align:left";><a href="#none" onclick="testMessageBox(event);">弹出窗口</a></div>  
  91. <div style="text-align:left;padding-left:20px;padding-top:10px";><select><option>下拉</option></select>弹出窗口时会将其隐藏,关闭时会让其显示,目的是在IE中防止弹出的DIV挡不住下拉框</div>  
  92. <div style="text-align:center";><a href="#none" onclick="testMessageBox(event);">弹出窗口</a></div>  
  93. <div style="text-align:right";><a href="#none" onclick="testMessageBox(event);">弹出窗口</a></div>  
  94. </div>  
  95. </body>  
  96. </html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值