JavaScript+DIV模态对话框的完美实现(克服select问题)

对于JavaScript+DIV模态对话框的方法很多,但是普遍都存在一个缺点,就是select不可见。一下是我从一个国外论坛上看到的实现,其完美的解决了我们之前所看到的select不可见问题。

 

 

 var maskpanel=function()
    {
        this.divobj;
        this.show=function()
        {
          if(!document.getElementById("xdivmasking"))
          {
              var divEle=document.createElement('div');
              divEle.setAttribute("id","xdivmasking");
              document.body.appendChild(divEle);
              var divSty=document.getElementById("xdivmasking").style;
              divSty.position="absolute";divSty.top="0px";divSty.left="0px";divSty.zIndex="46";divSty.opacity=".50";divSty.backgroundColor="#000";
              divSty.filter="alpha(opacity=50)";

              var divFram=document.createElement('iframe');
              divFram.setAttribute("id","xmaskframe");
              document.body.appendChild(divFram);
              divSty=document.getElementById("xmaskframe").style;
              divSty.position="absolute";divSty.top="0px";divSty.left="0px";divSty.zIndex="45";divSty.border="none";divSty.filter="alpha(opacity=0)";
           }

           this.divobj=document.getElementById("xdivmasking");
           this.waitifrm=document.getElementById("xmaskframe");
          
           var dsh=document.documentElement.scrollHeight;
           var dch=document.documentElement.clientHeight;
           var dsw=document.documentElement.scrollWidth;
           var dcw=document.documentElement.clientWidth;
          
           var bdh=(dsh>dch)?dsh:dch;
           var bdw=(dsw>dcw)?dsw:dcw;

           this.waitifrm.style.height=this.divobj.style.height=bdh+'px';
           this.waitifrm.style.width=this.divobj.style.width=bdw+'px'; 
           this.waitifrm.style.display=this.divobj.style.display="block";
        };
        this.hide=function()
        {
            this.waitifrm.style.display=this.divobj.style.display="none";
        };
    }

 

 

将以上代码包含于body体的script块中。

显示实现:

divmask=new maskpanel();   

divmask.show();  

 

 

关闭实现:

 

divmask.hide();  

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值