javascript inneHTML的地雷
更新時間:2010年02月20日 10:48:27 作者:
大家都喜歡用innerHTML添加內(nèi)容,但是innerHTML這東西在兩大陣營中有許多不同。
回顧一下,IE會把標(biāo)簽內(nèi)前面的一些空白kill掉,還會把它里面標(biāo)簽統(tǒng)統(tǒng)大寫,會顯示動態(tài)添加的屬性,在某些元素中,它還是只讀的。這個由IE發(fā)明的東西,最后被爆如此多缺陷,真是令人心寒。不過innerHTML還有一地雷,存在于最標(biāo)準(zhǔn)的火狐中,看下面代碼:
var newTable = document.createElement('table');
document.body.appendChild(newTable);
var newTr = document.createElement('tr');
var rowContent = '<td>司徒正美 </td><td><em>RestlessDream</em></td>';
newTr.innerHTML = rowContent;
newTable.appendChild(newTr);
alert(newTable.innerHTML)
if (rowContent.toLowerCase() == newTr.innerHTML.toLowerCase()) {
alert("一定如我所愿!");
}else {
alert("你踩雷了!");
}
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
當(dāng)我們把innerHTML加入到tr節(jié)點時,它會被firefox解析成:
而不再是原來的:
td標(biāo)簽被去掉了!我想是不是與加入DOM樹的順序有關(guān),調(diào)整一下:
var newTable = document.createElement('table');
document.body.appendChild(newTable);
var newTr = document.createElement('tr');
newTable.appendChild(newTr);
var rowContent = '<td>司徒正美 </td><td><em>RestlessDream</em></td>';
newTr.innerHTML = rowContent;
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
這樣就解決了firefox的情況!
復(fù)制代碼 代碼如下:
var newTable = document.createElement('table');
document.body.appendChild(newTable);
var newTr = document.createElement('tr');
var rowContent = '<td>司徒正美 </td><td><em>RestlessDream</em></td>';
newTr.innerHTML = rowContent;
newTable.appendChild(newTr);
alert(newTable.innerHTML)
if (rowContent.toLowerCase() == newTr.innerHTML.toLowerCase()) {
alert("一定如我所愿!");
}else {
alert("你踩雷了!");
}
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
當(dāng)我們把innerHTML加入到tr節(jié)點時,它會被firefox解析成:
復(fù)制代碼 代碼如下:
司徒正美 <em>RestlessDream</em>
而不再是原來的:
復(fù)制代碼 代碼如下:
<td>司徒正美 </td><td><em>RestlessDream</em></td>
td標(biāo)簽被去掉了!我想是不是與加入DOM樹的順序有關(guān),調(diào)整一下:
復(fù)制代碼 代碼如下:
var newTable = document.createElement('table');
document.body.appendChild(newTable);
var newTr = document.createElement('tr');
newTable.appendChild(newTr);
var rowContent = '<td>司徒正美 </td><td><em>RestlessDream</em></td>';
newTr.innerHTML = rowContent;
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
這樣就解決了firefox的情況!
相關(guān)文章
手淘flexible.js框架使用和源代碼講解小結(jié)
手淘框架是一個用來適配移動端的js框架,這篇文章主要介紹了手淘flexible.js框架使用和源代碼講解小結(jié),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-10-10理解與使用JavaScript中的回調(diào)函數(shù)
這篇文章主要介紹了JavaScript中的回調(diào)函數(shù),想詳細(xì)了解回調(diào)函數(shù)的同學(xué),一定要看一下2021-04-04js匿名函數(shù)的調(diào)用示例(形式多種多樣)
匿名函數(shù)就是沒有實際名字的函數(shù),javaScript的匿名函數(shù)形式多樣,下面就一一為大家羅列出來2014-08-08