公司W(wǎng)EB項目要求是必須兼容FF3,IE6/7/8。本文所述為IE6下的一個BUG.
項目里面寫了一個自己封裝的彈出層,原理是先動態(tài)添加一個遮罩層,再動態(tài)添加一個DIV(Table)層(做彈出層的PNG半透明邊框效果),DIV里面動態(tài)添加一個IFrame,這個Iframe頁面指向一個現(xiàn)存的HTM文件。
如果這個HTM文件中,包含文本輸入框這樣的一些表單元素,在IE6下就會出婁子了。
測試組的人說了,彈出層打開后,“經(jīng)常”無法獲取文本框的焦點,就是鼠標(biāo)點文本框無法獲取焦點并顯示輸入標(biāo)記,仿佛被什么透明層給蓋住了。但有時是正常的,可謂間歇性精神障礙。有的機(jī)子上百分之五十的幾率出現(xiàn),有的機(jī)子上百分之三十左右的幾率出現(xiàn)。
少不了得做一番測試和分析了。
經(jīng)我在虛擬機(jī)IE6測試,也發(fā)現(xiàn)的確如測試組的人所說。
我確信不可能有多余的覆蓋層,因為除文本框之外,它周圍的任何文字都可以正常的用鼠標(biāo)選中,它周圍的任何元素包括這個文本框本身也能響應(yīng)onclick事件,只是無論怎么點,都無法獲取輸入焦點。(文本框沒有設(shè)置readOnly或者disabled)
但是,某些小動作就可以讓它們恢復(fù)正常,比如在這個Iframe里右鍵刷新一下,或者是在這個Iframe里按'TAB'鍵將焦點切換到任何一個文本框,這時,所有的文本框都可以用點擊正常獲得焦點了。還真是變態(tài)!
咱總不能說這是IE6的BUG我們程序無法解決吧,領(lǐng)導(dǎo)是不聽這話的。
經(jīng)過一番努力,還是有了解決方案。
我發(fā)現(xiàn),手動調(diào)用一下任何一個(通常是第一個)文本框的focus()方法就可以讓所有的文本框恢復(fù)神智了。于是寫了一個公共腳本,在Iframe內(nèi)的頁面末尾,獲取第一個文本框并調(diào)用其focus(),經(jīng)測百來次,再沒碰見無法獲取焦點的情況,問題解決。
下面是網(wǎng)友回復(fù):
彈出的那個標(biāo)簽是<a />標(biāo)簽吧?
換成<span />標(biāo)簽似乎就OK了
新聞熱點
疑難解答
圖片精選