一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

Firefox返回時Iframe的顯示Bug的解決方法

<script type="text/Javascript">//<![CDATA[
if(getCookie('firefoxIframe')){
document.write('<p id="addAd"><a href="cookie.html">點擊這里刪除這個iframe</a></p>');
document.write('<iframe height="120" width="300" marginheight="0" marginwidth="0"
frameborder="0" src="nAdPre.swf"></iframe>');
}else{
document.write('<p id="addAd"><a href="cookie.html">點擊這里增加一個iframe</a></p>');
}
//]]></script>
打開Bug演示,由于cookie不存在,顯示的三個flash都是通過Iframe實現的 
點擊“點擊這里增加一個iframe廣告”,跳轉到一個新的頁面寫入名為firefoxIframe的Cookie 
點擊“返回”或者瀏覽器的返回按鈕,回到Bug演示頁面,發現iframe里面的flash錯位,即位置2的iframe鏈接的flash并沒有載入,顯示的是位置3的flash,位置3的顯示的是位置4的flash,位置4的flash卻依舊存在。 
關閉標簽頁(不是關閉整個瀏覽器,如果關閉整個瀏覽器Cookie也失效)或新打開一個標簽頁重新載入該頁面,4個Iframe正常顯示4個flash 
此時如果點擊“點擊這里刪除這個iframe廣告”,跳轉到新頁面刪除Cookie,返回也發現Iframe中的flash錯位 
如果寫入Cookie或者刪除Cookie時,不通過瀏覽器的返回,直接通過網址訪問,則不會出現錯位 
簡單分析和解決方案
似乎Firefox返回時,Javascript重新執行了,但是Iframe并未依據src屬性重新載入,而是給Iframe和src以類似編號似的配對,而由于返回時Javascript的執行,導致Iframe多了一個(或少了一個),這就導致后面的配對錯位。

以上僅為猜測,但這的確是Firefox(2.0.0.3)的一個bug,IE返回時Javascript重新執行,并且Iframe的依據src重新載入,Opera返回時Javascript不重新執行,頁面沒有變化。

解決方案是在文本中增加一個隱藏的Iframe來占位,上面代碼修改如下代碼如下:

document.write('<p id="addAd"><a href="cookie.html">點擊這里增加一個iframe</a></p>');
//把上面的代碼修改成為
document.write('<iframe src="#" style="display:none;"></iframe>');
document.write('<p id="addAd"><a href="cookie.html">點擊這里增加一個iframe</a></p>');

HTML/CSS技術Firefox返回時Iframe的顯示Bug的解決方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产精品视频无圣光一区 | 日本精品一区二区三区在线视频| 激情六月丁香婷婷 | 中文字幕在线视频网 | 亚洲精品高清国产一线久久97 | 久久精品久久久久久久久人 | 999免费视频 | www.黄色.con | 成人午夜视频在线观 | 麻豆一区区三三四区产品麻豆 | 午夜色大片在线观看 | 五月九九| 色网在线免费观看 | 日本福利在线观看 | 国产九色 | 成人午夜无人区一区二区 | 亚洲网站视频 | a毛片全部播放免费视频完整18 | 欧美一级做一级做片性十三 | 婷婷激情四射网 | 四虎影视久久久免费 | xxxxx在线 | 99久久精品免费看国产高清 | 夜夜操影院 | 亚洲区欧美区小说区图片区 | 亚洲国产精品免费在线观看 | 久久久91精品国产一区二区 | 国产成人亚洲综合 | 69精品免费视频 | 久久伊人精品一区二区三区 | 国产极品自拍 | 成人福利在线观看免费视频 | 美女黄网站| 国产精品久久久久久久久齐齐 | 视频二区中文字幕 | 欧美成成人免费 | 久久久最新精品 | 免费一区二区三区 | 国产亚洲福利精品一区二区 | 成人91在线 | 涩涩涩视频在线观看免费 |