解决控件遮挡问题:关于有窗口元素和无窗口元素
程序员文章站
2022-04-28 14:20:57
不知道朋友们有没有碰到过控件的遮挡问题,最典型的就是dropdownlist和activex的遮挡,html的z-index就是用于处理这个问题,但是直接设置这个属性还不行...
不知道朋友们有没有碰到过控件的遮挡问题,最典型的就是dropdownlist和activex的遮挡,html的z-index就是用于处理这个问题,但是直接设置这个属性还不行,因为这中间还牵扯到有窗口元素和无窗口元素的问题。
有窗口元素大概有以下几种:
<object> 、activex控件 、plug-ins、dhtml scriptlets、select elements(即dropdownlist的html表现)、ie5.01以前的iframes
无窗口元素包括:
无窗口的activex控件、ie5.5以后的iframes、大部分的dhtml元素
其中很值得一提的就是activex控件,默认情况下,vb和mfc的控件是有窗口的,atl控件是无窗口的,但是activex控件是作为无窗口来进行实现而且实际上被归类到无窗口元素中。
不管容器怎么设定,所有的有窗口元素都会出现在无窗口的元素之上,有窗口元素和无窗口元素内部自身互相会遵循z-index属性,它们会被绘制在不同的平面上进行显示,设置z-index只能对它们所在的平面起作用,而且有窗口元素的平面始终处于无窗口元素平面之上。
那么解决遮挡问题的思路就很简单了,把我们的元素封装进一个div中,代码示例如下:
<div id="pal2" style="display: inline; z-index: 8; left: 80px; width: 360px; position: absolute; top: 80px; height: 168px">
<object id="dhtmltest" style="z-index: 8; width: 352px; height: 168px" type="text/x-scriptlet" data="testdivdropdownlist.htm" viewastext>
</object></div>
div的z-index为8,然后将select的z-index调为7即可(只需要比div的z-index小)。
有窗口元素大概有以下几种:
<object> 、activex控件 、plug-ins、dhtml scriptlets、select elements(即dropdownlist的html表现)、ie5.01以前的iframes
无窗口元素包括:
无窗口的activex控件、ie5.5以后的iframes、大部分的dhtml元素
其中很值得一提的就是activex控件,默认情况下,vb和mfc的控件是有窗口的,atl控件是无窗口的,但是activex控件是作为无窗口来进行实现而且实际上被归类到无窗口元素中。
不管容器怎么设定,所有的有窗口元素都会出现在无窗口的元素之上,有窗口元素和无窗口元素内部自身互相会遵循z-index属性,它们会被绘制在不同的平面上进行显示,设置z-index只能对它们所在的平面起作用,而且有窗口元素的平面始终处于无窗口元素平面之上。
那么解决遮挡问题的思路就很简单了,把我们的元素封装进一个div中,代码示例如下:
<div id="pal2" style="display: inline; z-index: 8; left: 80px; width: 360px; position: absolute; top: 80px; height: 168px">
<object id="dhtmltest" style="z-index: 8; width: 352px; height: 168px" type="text/x-scriptlet" data="testdivdropdownlist.htm" viewastext>
</object></div>
div的z-index为8,然后将select的z-index调为7即可(只需要比div的z-index小)。
上一篇: Linux多线程锁属性设置方法