ActiveX插件的Z-Index屬性無效問題解決

在Web開發中我們經常通過z-index設置多個元素之間的層疊關係,這種方式在多數情況下很有效,但是如果遇到有窗體元素時這種方式常常顯得無能爲力,今天我們就一塊看一下如何有效的解決這個問題。

網頁控件分爲兩大類:有窗體元素和無窗體元素。無窗體元素包括大多數html元素(例如div、table等)、無窗體的ActivX插件、iframe等;有窗體的元素包括<Object>元素、ActiveX插件、Plug-ins插件、Select元素等。所有的有窗體元素都會出現在無窗體元素之上,而有窗體元素和無窗體元素自身遵循z-index屬性約束(注意使用z-index必須設置相應元素的position爲absolute)。所有的無窗體元素都被瀏覽器渲染在同一個MSHTML平面,而有窗體元素被渲染在一個單獨的MSHTML平面上。在同一個MSHTML平面當然可以通過設置z-index屬性設置其層疊關係,但是對於不同平面上的元素,這個屬性卻無能爲力。這裏需要注意ActiveX插件,默認情況下VB和MFC控件是有窗體的,而ALT是無窗體的。

雖然上面說到ifame屬於無窗體元素,但是在ie中它卻橫跨兩邊。無論是有窗體元素還是無窗體元素在顯示時都會考慮iframe的順序。因此如果要解決無窗體元素和有窗體元素之間的層疊關係時我們可以藉助於iframe:通過把有窗體元素放到iframe中,然後設置iframe的z-index大於無窗體元素來解決二者層疊關係無法調整的問題;或者在無窗體元素內部放置一個iframe,設置其z-index小於無窗體元素並且其大小同無窗體元素相同;當然如果你覺得這兩種方式都太麻煩的話可以使用jQuery的bgiframe插件,它的原理同第二種方式,不過使用起來就簡單多了。

上面的方式或許可以解決大多數情況,但是實際應用中或多或少會給你造成一些額外的開發成本,如果你的項目中使用的Ext來進行前臺開發,那麼很幸運,Ext原生就對遮蓋有窗體元素進行了支持。只需要在腳本開始處加上Ext.useShims=true;即可。

另外:多數情況下div被flash遮蓋不用像上面這麼麻煩,只需要設置wmode屬性爲transparent即可。


轉自:http://www.csdn123.com/html/20130206/51/f551fce9db8bf665de35d0cf4edb351c.htm

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章