DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> IE6,IE7下js動態加載圖片不顯示錯誤
IE6,IE7下js動態加載圖片不顯示錯誤
編輯:關於JavaScript     
先描述一下出現這種匪夷所思bug的背景:
我在頁面加載的時候加載一堆小縮略圖,<a href="javascript:void(0);" onclick="switch_image('1.jpg')"><img src="1.thumb.jpg" /></a>
這麼多小的縮略圖標簽循環平鋪下來,當單擊小的圖片時,動態加載大的圖片顯示,就類似於淘寶的商品查看圖片。頁面上有一個標簽:
<div id="pic-box"><img src="" id="big-image" /></div>
為了節省流量,加快頁面載入速度,先不加載大圖,當用戶單擊小圖時,動態加載一張大圖顯示。
復制代碼 代碼如下:
<script>
function switch_image(im)
{
document.getElementById('big-image').src=im;
}
</script>

這種方式在IE6,7外所有的浏覽器工作都正常,比如 IE8,Firefox, Opera, chrome, Safari。。。
就是IE6,7這兩個浏覽器加載不了,單擊小圖的時候,有時候你能加載,有時候加載一半,有時候不能加載。
我以為問題出在src這個東西上面,有可能IE6,7修改src不能正確加載圖片,於是嘗試把切換函數修改為:
document.getElementById('pic-box').innerHTML='<img src="' + im + '" />';
IE6,7還是不行,於是想,有可能是圖片被緩存了,那麼加上隨機數:
document.getElementById('pic-box').innerHTML='<img src="' + im + '?r=' + Math.random() + '" />';
IE6,7依然不行。。
於是在想,可能是img用在innerHTML裡面出現的問題,所以,改成用 appendChild
var img = document.createElement('img');
img.src= im;
document.getElementById('pic-box').appendChild(img);
還是不行。
再修改成用 new image來:

var img = new Image();
img.src= im;
document.getElementById('pic-box').appendChild(img);
還是不行。
百思不得其解,想,難道IE6,7不能動態加載圖片嗎?難道是img標簽的問題?
既然這樣就換成背景圖加載吧,於是
document.getElementById('pic-box').style.background="url(" + im + ")";
IE6,7依然不行,上面這麼多方法除IE6,7外其他都是正常的。
只有不停的Google,結果google到了:
IE6,7只有在用<a onclick="switch_image()" href="javascript:void(0);"></a>這樣
動態加載圖片是才會出現這種情況,google到的一篇說明:

有幾個吃飽了沒事兒干的老外反復試驗發現這個問題是ie6中一個底層機制的bug,之後的版本已經解決了。
據說<a href="javascript:void(0)">或者<a href=#">這樣使用a標簽的話並不能阻止a標簽最後觸發一個什麼行為,
導致ie6會錯誤的認為頁面刷新或者重定向了,並且中斷了當前所有連接,這樣新圖片的加載就被aborted了。
當然這些吃飽了沒事兒干的老外們也提出了各種匪夷所思復雜無比的解決方案。

最簡單的方法有兩個,一個是這樣使用a標簽<a href="switch_image(); return false;">,另外一個就是用div替換a標簽來用。

實際上我發現不僅是IE6,IE7也同樣有這個bug,還有,采用:<a href="switch_image(); return false;">並不能解決問題。

所以推薦用其他標簽替換a標簽,最後一怒之下把所有的a標簽替換為span,從此就再也沒出現這樣的問題了。
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved