innerHTML和getElementsByName在IE下面的bug的解決_javascript技巧
來源:懂視網
責編:小采
時間:2020-11-27 20:48:38
innerHTML和getElementsByName在IE下面的bug的解決_javascript技巧
innerHTML和getElementsByName在IE下面的bug的解決_javascript技巧:比如有這樣一個問題。 代碼如下: 在這div 中,加入一個播放嗎列表。這列表用innerHTML 加入。 代碼如下: var plst = null; plst = player.getPlaylist(); if (plst) { var txt = ''; for(var i in plst) { txt
導讀innerHTML和getElementsByName在IE下面的bug的解決_javascript技巧:比如有這樣一個問題。 代碼如下: 在這div 中,加入一個播放嗎列表。這列表用innerHTML 加入。 代碼如下: var plst = null; plst = player.getPlaylist(); if (plst) { var txt = ''; for(var i in plst) { txt
比如有這樣一個問題。
代碼如下:
在這div 中,加入一個播放嗎列表。這列表用innerHTML 加入。
代碼如下:
var plst = null;
plst = player.getPlaylist();
if (plst) {
var txt = '';
for(var i in plst) {
txt += '';
txt += '正在播放...';
txt += '

';
txt += '
' + plst[i].title + '
';
txt += "";
}
var obj= document.getElementById("playlist");
if (obj) {
obj.innerHTML = txt;
}
}
中間的復雜代碼不用去管了,現在我要把name 為 playing 的 div 取出來。很容易想到用
getElementsByName
但是,非常奇怪的是,在ie 下面 就是 取不到。getElementById 完全可以用。
下面是一個不錯的解決方案:
代碼如下:
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;
}
改成這個函數,就可以取了。只是要多一個參數了。
不知道博友們還有沒有其他的解決方案,這個解決方案不是很完美。一定要在評論里面留言一下。
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com
innerHTML和getElementsByName在IE下面的bug的解決_javascript技巧
innerHTML和getElementsByName在IE下面的bug的解決_javascript技巧:比如有這樣一個問題。 代碼如下: 在這div 中,加入一個播放嗎列表。這列表用innerHTML 加入。 代碼如下: var plst = null; plst = player.getPlaylist(); if (plst) { var txt = ''; for(var i in plst) { txt