欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

innerHTML 和 getElementsByName 在IE下面的bug 的解決

 更新時(shí)間:2010年04月09日 13:04:21   作者:  
innerHTML 真的一個(gè)麻煩的東西。IE 和 firefox 對(duì)dom 處理的方式不是很一樣。IE 對(duì)動(dòng)態(tài)加載的很多dom 不支持動(dòng)態(tài)更新。
比如有這樣一個(gè)問題。
復(fù)制代碼 代碼如下:

<div id="playlist">
</div>

在這div 中,加入一個(gè)播放嗎列表。這列表用innerHTML 加入。
復(fù)制代碼 代碼如下:

var plst = null;
plst = player.getPlaylist();
if (plst) {
var txt = '';
for(var i in plst) {
txt += '<a name="fv_item_a_' + i + '"></a><div class="fv_item" id="fv_item_'+ i +'"><div class="playing_bg" name="playing_bg"></div>';
txt += '<div class="playing" name="playing">正在播放...</div>';
txt += '<img src="' + plst[i].image + '" width="80" height="50" class="fv_playlist_img" />';
txt += '<p class="fv_playlist_title"> ' + plst[i].title + ' </p>';
txt += "</div>";
}
var obj= document.getElementById("playlist");
if (obj) {
obj.innerHTML = txt;
}
}

中間的復(fù)雜代碼不用去管了,現(xiàn)在我要把name 為 playing 的 div 取出來。很容易想到用
getElementsByName
但是,非常奇怪的是,在ie 下面 就是 取不到。getElementById 完全可以用。
下面是一個(gè)不錯(cuò)的解決方案:
復(fù)制代碼 代碼如下:

function GetElementsByName(tag, name) {
var elem = document.getElementsByTagName(tag);
var arr = [];
var index = 0;
var l = elem.length;
for(var i = 0; i < l; i++)
{
var att = elem[i].getAttribute("name");
if(att == name) {
arr[index++] = elem[i];
}
}
return arr;
}

改成這個(gè)函數(shù),就可以取了。只是要多一個(gè)參數(shù)了。
不知道博友們還有沒有其他的解決方案,這個(gè)解決方案不是很完美。一定要在評(píng)論里面留言一下。

相關(guān)文章

最新評(píng)論