select被iframe给挡住,怎么办。

时间:2022-12-20 15:32:16
select控件被iframe给挡住了,请问有办法么。
具体情况是这样的。
我设置了一个嵌在iframe中的select,正常显示没有问题。
然后我又设置了一个z-index最高的遮罩层,作为弹出消息时的msgbox,当这个遮罩层出现的时候select控件就消失了,不知道是为什么原因,求助求助。

7 个解决方案

#1


DIV做遮罩层的时候,是不是遮挡住SELECT的. 但网上有些办法是,当遮罩层弹出的时候,就把SELECT隐藏.

不知道楼主是不是这种情况. 如果是的话,在弹出遮罩层的代码那里找找有没有隐藏SELECT的属性,把它去掉.

或者贴代码来看看

#2


贴代码看看

#3


你这样说很不清楚,别人没法准确理解你的意思哦

#4


'<div id="msgBoxMask" class="msgbox_mask" style="display:none;">'+
            '<iframe class="msgbox_mask" style="Z-INDEX:-1;FILTER:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=0);LEFT:0px; VISIBILITY:inherit;WIDTH:1000px;POSITION:absolute;TOP:0px;HEIGHT:700px"></iframe>'+
            '</div>' + 
            '<div class="msgbox" style="display:none; z-index:100000;position:absolute;" id="msgBox">' + 
            '<div class="msgbox_title" id="msgBoxTitle"></div>' + 
            '<div class="msgbox_icon" id="msgBoxIcon"></div>' + 
            '<div class="msgbox_content" id="msgBoxContent"></div>' + 
            '<div class="msgbox_control" id="msgBoxControl"></div></div>'; 

这个是遮罩层的代码。
.msgbox_mask{
    position:absolute;
    left:0px;
    top:0px;
    z-index:99999;
    background-color:#333333;
    width:100%;
    height:100%;
    filter:alpha(opacity=90);
opacity:0.9;} 
这个是css
select就是在一个普通的div里。

#5


原本我的用意是想用iframe禁掉select。
因为原本当msgbox弹出的时候整个画面都被禁用但唯独select还是enable的。
不知道各位有什么方法可以帮我禁掉这个时候的select,小弟谢过了。

#6


就是嘛,给个例子你,你把相关的代码弄过去就行了

<!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">  
<head>  
<title></title>  
<style>  
html,body{font-size:12px;margin:0px;height:100%;}  
.mesWindow{border:#666 1px solid;background:#fff;}  
.mesWindowTop{border-bottom:#eee 1px solid;margin-left:4px;padding:3px;font-weight:bold;text-align:left;font-size:12px;}  
.mesWindowContent{margin:4px;font-size:12px;}  
.mesWindow .close{height:15px;width:28px;border:none;cursor:pointer;text-decoration:underline;background:#fff}  
</style>  
<script>  
var isIe=(document.all)?true:false;  
//设置select的可见状态  
function setSelectState(state)  
{  
 var objl=document.getElementsByTagName('select');  
 for(var i=0;i<objl.length;i++)  
 {  
 objl[i].style.visibility=state;  
 }  
}  
function mousePosition(ev)  
 {  
 if(ev.pageX || ev.pageY)  
 {  
 return {x:ev.pageX, y:ev.pageY};  
 }  
 return {  
 x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,y:ev.clientY + document.body.scrollTop - document.body.clientTop  
 };  
 }  
//弹出方法  
function showMessageBox(wTitle,content,pos,wWidth)  
{  
 closeWindow();  
 var bWidth=parseInt(document.documentElement.scrollWidth);  
 var bHeight=parseInt(document.documentElement.scrollHeight);  
 if(isIe){  
 setSelectState('hidden');}  
 var back=document.createElement("div");  
 back.id="back";  
 var styleStr="top:0px;left:0px;position:absolute;background:#666;width:"+bWidth+"px;height:"+bHeight+"px;";  
 styleStr+=(isIe)?"filter:alpha(opacity=40);":"opacity:0.40;";  
 back.style.cssText=styleStr;  
 document.body.appendChild(back);  
 var mesW=document.createElement("div");  
 mesW.id="mesWindow";  
 mesW.className="mesWindow";  
 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>";  
  
 styleStr="left:"+(((pos.x-wWidth)>0)?(pos.x-wWidth):pos.x)+"px;top:"+(pos.y)+"px;position:absolute;width:"+wWidth+"px;";  
 mesW.style.cssText=styleStr;  
 document.body.appendChild(mesW);  
}  
 function showBackground(obj,endInt)  
{  
 obj.filters.alpha.opacity+=1;  
 if(obj.filters.alpha.opacity<endInt)  
 {  
 setTimeout(function(){showBackground(obj,endInt)},8);  
 }  
}  
//关闭窗口  
function closeWindow()  
{  
 if(document.getElementById('back')!=null)  
 {  
 document.getElementById('back').parentNode.removeChild(document.getElementById('back'));  
 }  
 if(document.getElementById('mesWindow')!=null)  
 {  
 document.getElementById('mesWindow').parentNode.removeChild(document.getElementById('mesWindow'));  
 }  
  
 if(isIe){  
 setSelectState('');}  
}  
//测试弹出  
function testMessageBox(ev)  
{  
 var objPos = mousePosition(ev);  
 messContent="<div style='padding:20px 0 20px 0;text-align:center'>消息正文</div>";  
 showMessageBox('窗口标题',messContent,objPos,350);  
}  
</script>  
</head>  
<body>  
<div style="padding:20px">  
<div style="text-align:left";><a href="#none" onclick="testMessageBox(event);">弹出窗口</a></div>  
<div style="text-align:left;padding-left:20px;padding-top:10px";><select><option>下拉</option></select>弹出窗口时会将其隐藏,关闭时会让其显示,目的是在IE中防止弹出的DIV挡不住下拉框</div>  
<div style="text-align:center";><a href="#none" onclick="testMessageBox(event);">弹出窗口</a></div>  
<div style="text-align:right";><a href="#none" onclick="testMessageBox(event);">弹出窗口</a></div>  
</div>  
</body>  
</html>  

#1


DIV做遮罩层的时候,是不是遮挡住SELECT的. 但网上有些办法是,当遮罩层弹出的时候,就把SELECT隐藏.

不知道楼主是不是这种情况. 如果是的话,在弹出遮罩层的代码那里找找有没有隐藏SELECT的属性,把它去掉.

或者贴代码来看看

#2


贴代码看看

#3


你这样说很不清楚,别人没法准确理解你的意思哦

#4


'<div id="msgBoxMask" class="msgbox_mask" style="display:none;">'+
            '<iframe class="msgbox_mask" style="Z-INDEX:-1;FILTER:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=0);LEFT:0px; VISIBILITY:inherit;WIDTH:1000px;POSITION:absolute;TOP:0px;HEIGHT:700px"></iframe>'+
            '</div>' + 
            '<div class="msgbox" style="display:none; z-index:100000;position:absolute;" id="msgBox">' + 
            '<div class="msgbox_title" id="msgBoxTitle"></div>' + 
            '<div class="msgbox_icon" id="msgBoxIcon"></div>' + 
            '<div class="msgbox_content" id="msgBoxContent"></div>' + 
            '<div class="msgbox_control" id="msgBoxControl"></div></div>'; 

这个是遮罩层的代码。
.msgbox_mask{
    position:absolute;
    left:0px;
    top:0px;
    z-index:99999;
    background-color:#333333;
    width:100%;
    height:100%;
    filter:alpha(opacity=90);
opacity:0.9;} 
这个是css
select就是在一个普通的div里。

#5


原本我的用意是想用iframe禁掉select。
因为原本当msgbox弹出的时候整个画面都被禁用但唯独select还是enable的。
不知道各位有什么方法可以帮我禁掉这个时候的select,小弟谢过了。

#6


就是嘛,给个例子你,你把相关的代码弄过去就行了

<!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">  
<head>  
<title></title>  
<style>  
html,body{font-size:12px;margin:0px;height:100%;}  
.mesWindow{border:#666 1px solid;background:#fff;}  
.mesWindowTop{border-bottom:#eee 1px solid;margin-left:4px;padding:3px;font-weight:bold;text-align:left;font-size:12px;}  
.mesWindowContent{margin:4px;font-size:12px;}  
.mesWindow .close{height:15px;width:28px;border:none;cursor:pointer;text-decoration:underline;background:#fff}  
</style>  
<script>  
var isIe=(document.all)?true:false;  
//设置select的可见状态  
function setSelectState(state)  
{  
 var objl=document.getElementsByTagName('select');  
 for(var i=0;i<objl.length;i++)  
 {  
 objl[i].style.visibility=state;  
 }  
}  
function mousePosition(ev)  
 {  
 if(ev.pageX || ev.pageY)  
 {  
 return {x:ev.pageX, y:ev.pageY};  
 }  
 return {  
 x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,y:ev.clientY + document.body.scrollTop - document.body.clientTop  
 };  
 }  
//弹出方法  
function showMessageBox(wTitle,content,pos,wWidth)  
{  
 closeWindow();  
 var bWidth=parseInt(document.documentElement.scrollWidth);  
 var bHeight=parseInt(document.documentElement.scrollHeight);  
 if(isIe){  
 setSelectState('hidden');}  
 var back=document.createElement("div");  
 back.id="back";  
 var styleStr="top:0px;left:0px;position:absolute;background:#666;width:"+bWidth+"px;height:"+bHeight+"px;";  
 styleStr+=(isIe)?"filter:alpha(opacity=40);":"opacity:0.40;";  
 back.style.cssText=styleStr;  
 document.body.appendChild(back);  
 var mesW=document.createElement("div");  
 mesW.id="mesWindow";  
 mesW.className="mesWindow";  
 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>";  
  
 styleStr="left:"+(((pos.x-wWidth)>0)?(pos.x-wWidth):pos.x)+"px;top:"+(pos.y)+"px;position:absolute;width:"+wWidth+"px;";  
 mesW.style.cssText=styleStr;  
 document.body.appendChild(mesW);  
}  
 function showBackground(obj,endInt)  
{  
 obj.filters.alpha.opacity+=1;  
 if(obj.filters.alpha.opacity<endInt)  
 {  
 setTimeout(function(){showBackground(obj,endInt)},8);  
 }  
}  
//关闭窗口  
function closeWindow()  
{  
 if(document.getElementById('back')!=null)  
 {  
 document.getElementById('back').parentNode.removeChild(document.getElementById('back'));  
 }  
 if(document.getElementById('mesWindow')!=null)  
 {  
 document.getElementById('mesWindow').parentNode.removeChild(document.getElementById('mesWindow'));  
 }  
  
 if(isIe){  
 setSelectState('');}  
}  
//测试弹出  
function testMessageBox(ev)  
{  
 var objPos = mousePosition(ev);  
 messContent="<div style='padding:20px 0 20px 0;text-align:center'>消息正文</div>";  
 showMessageBox('窗口标题',messContent,objPos,350);  
}  
</script>  
</head>  
<body>  
<div style="padding:20px">  
<div style="text-align:left";><a href="#none" onclick="testMessageBox(event);">弹出窗口</a></div>  
<div style="text-align:left;padding-left:20px;padding-top:10px";><select><option>下拉</option></select>弹出窗口时会将其隐藏,关闭时会让其显示,目的是在IE中防止弹出的DIV挡不住下拉框</div>  
<div style="text-align:center";><a href="#none" onclick="testMessageBox(event);">弹出窗口</a></div>  
<div style="text-align:right";><a href="#none" onclick="testMessageBox(event);">弹出窗口</a></div>  
</div>  
</body>  
</html>  

#7