zoukankan      html  css  js  c++  java
  • DIV弹出层无法遮罩ActiveX控件的解决方案

             使用JS做DIV弹出层时,一般地在IE下是无法遮罩ActiveX控件的,同时在IE6下Select也遮罩不住。在IE中ActiveX默认永远显示在最顶层,因此通过设置Style的Z-Index属性也无法改变遮罩关系的。在信息系统软件中,许多场合由于性能、操作等原因,往往会使用ActiveX代替Html来完成功能,从而成为不可回避的问题。

    var sd = XX.style.display;
    XX.style.display = "none";
     ... 
    //关闭弹出层后显示 
    XX.style.display = sd;

              最容易想到的方法是在弹出DIV层前隐藏控件对应的object,关闭层后再显示出来。如果只是当个页面诚然这样简单,但如果存在多个Iframe嵌套的话,对于其他Iframe也存在控件的话就比较麻烦。

              在IE6以后版本存在称之为shim的解决办法,基本思路是这样的,在当前页面动态创建一个iframe,其z-index比当前的要高,则这个iframe会呈现在最上方,然后将弹出的div的z-index设置比这个iframe的要高,此时弹出的div就能遮罩住ActiveX控件了,示意见如下简图(实际div是与iframe重合的)。

    shim示意图              当然还需要设置一些必要地属性,比较关键是设置iframe的src属性为javascript:false;,并设置display为none,透明度为0。

    //popDiv是弹出层,nowindex是当前的z-index
    popDiv.style.zIndex=nowindex+1;
    //加一个iframe以遮住ActiveX
    if($get("__iframeBodyCover" + winname )==null){
    	var iframeBodyCover = document.createElement("iframe");
            iframeBodyCover.id = "__iframeBodyCover"+winname;
            iframeBodyCover.style.cssText = "position:absolute;top:0;left:0;" + document.body.clientWidth+ "px; height:" + document.body.clientHeight + "px;background-color:#000000;filter:alpha(opacity=0);display:none;";
            iframeBodyCover.src ="javascript:false;";
            document.body.appendChild(iframeBodyCover);
    }
    //iframe的z-index比div的要低
    $get("__iframeBodyCover" + winname ).style.zIndex = nowindex;

                  当然这时候在IE6下自然也能遮罩住select了,方法还是有一点巧妙地,没有经验的可能比较难以想到,不过不知道是不是有更好地方法。

  • 相关阅读:
    cocos2dx源码分析之二:引擎的内存管理
    cocos2dx源码分析之一:大体运行流程
    对语言、层次和虚拟机的简单理解
    cocos2dx lua中异步加载网络图片,可用于显示微信头像
    对于c语言存储分配程序(malloc函数)实现的理解
    内存对齐的理解
    C和C++中#define的使用方法
    Unix系统中对于文件权限信息的本质理解
    npm 安装相关环境及测试
    Win7 之 NodeJS 安装
  • 原文地址:https://www.cnblogs.com/xiaopang2010/p/2206561.html
Copyright © 2011-2022 走看看