Javascript多種瀏覽器兼容寫(xiě)法分析第1/3頁(yè)
更新時(shí)間:2008年09月02日 00:44:44 作者:
隨著以Firefox為代表的第三方瀏覽器的興起,我們做的網(wǎng)站也不能再JUST IE了,如果把原來(lái)的一些javascript代碼放到IE以外的瀏覽器的話(huà),往往都不能正常運(yùn)行或出錯(cuò),所以這里介紹一下怎么改進(jìn)我們的JS,讓它能更加規(guī)范,更加具有兼容性。
示例代碼:
<body>
<table border="1" cellspacing="0" cellpadding="0" id="apple" >
<tbody>
<tr>
<td id="banana" style="color:red" >不吃蘋(píng)果</td>
</tr>
</tbody>
</table>
</body>
盡量采用W3C DOM 的寫(xiě)法
以前訪(fǎng)問(wèn)對(duì)象可能是:
document.all.apple 或者 apple
現(xiàn)在應(yīng)該采用:
document.getElementById("apple") 以ID來(lái)訪(fǎng)問(wèn)對(duì)象,且一個(gè)ID在頁(yè)面中必須是唯一的
document.getElementsByTagName("div")[0] 以標(biāo)簽名來(lái)訪(fǎng)問(wèn)對(duì)象
原來(lái)設(shè)置對(duì)象的屬性可能是:
document.all.apple.width=100 或 apple.width=100
現(xiàn)在應(yīng)該采用:
document.getElementById("apple").setAttribute("width","100")
document.getElementsByTagName("div")[0].setAttribute("width","100")
訪(fǎng)問(wèn)對(duì)象的屬性則采用:
document.getElementById("apple").getAttribute("width")
document.getElementsByTagName("div")[0].getAttribute("width")
W3C DOM在IE下的一些限制
因?yàn)槠鹣鹊腎E占據(jù)整個(gè)瀏覽器95%的份額,沒(méi)有競(jìng)爭(zhēng)壓力,所以這位老大就硬是要玩點(diǎn)另類(lèi),不完全按WEB標(biāo)準(zhǔn)來(lái)搞。
在IE下不能正確使用setAttribute來(lái)設(shè)置對(duì)象的style、class以及事件響應(yīng)屬性,
因此我還得按原來(lái)的點(diǎn)記法來(lái)訪(fǎng)問(wèn)和設(shè)置,以達(dá)到兼容各種瀏覽器的效果,如:
document.getElementById("banana").class
document.getElementById("banana").style.color
document.getElementById("banana").onclick
document.getElementById("banana").class="fruit"
document.getElementById("banana").style.color="blue"
document.getElementById("banana").onclick= function (){alert("我是香蕉")}
關(guān)于Firefox下的onload問(wèn)題
function over(){
alert("頁(yè)面加載完畢")
}
正常情況下,我們賦與onload響應(yīng)函數(shù)是:
document.body.onload= over
但是在Firefox下這樣無(wú)法執(zhí)行,
所以我們都都采用下面這種形式:
window.onload=over
關(guān)于IE下TABLE無(wú)法插入新行的問(wèn)題
IE下TABLE無(wú)論是用innerHTML還是appendChild插入<tr>都沒(méi)有效果,而其他瀏覽器卻顯示正常。解決他的方法是,將<tr>加到TABLE的<tbody>元素中,如下面所示:
var row = document.createElement("tr");
var cell = document.createElement("td");
var cell_text = document.createTextNode("香蕉不吃蘋(píng)果");
cell.appendChild(cell_text);
row.appendChild(cell);
document.getElementsByTagName("tbody")[0].appendChild(row);
<body>
<table border="1" cellspacing="0" cellpadding="0" id="apple" >
<tbody>
<tr>
<td id="banana" style="color:red" >不吃蘋(píng)果</td>
</tr>
</tbody>
</table>
</body>
盡量采用W3C DOM 的寫(xiě)法
以前訪(fǎng)問(wèn)對(duì)象可能是:
document.all.apple 或者 apple
現(xiàn)在應(yīng)該采用:
document.getElementById("apple") 以ID來(lái)訪(fǎng)問(wèn)對(duì)象,且一個(gè)ID在頁(yè)面中必須是唯一的
document.getElementsByTagName("div")[0] 以標(biāo)簽名來(lái)訪(fǎng)問(wèn)對(duì)象
原來(lái)設(shè)置對(duì)象的屬性可能是:
document.all.apple.width=100 或 apple.width=100
現(xiàn)在應(yīng)該采用:
document.getElementById("apple").setAttribute("width","100")
document.getElementsByTagName("div")[0].setAttribute("width","100")
訪(fǎng)問(wèn)對(duì)象的屬性則采用:
document.getElementById("apple").getAttribute("width")
document.getElementsByTagName("div")[0].getAttribute("width")
W3C DOM在IE下的一些限制
因?yàn)槠鹣鹊腎E占據(jù)整個(gè)瀏覽器95%的份額,沒(méi)有競(jìng)爭(zhēng)壓力,所以這位老大就硬是要玩點(diǎn)另類(lèi),不完全按WEB標(biāo)準(zhǔn)來(lái)搞。
在IE下不能正確使用setAttribute來(lái)設(shè)置對(duì)象的style、class以及事件響應(yīng)屬性,
因此我還得按原來(lái)的點(diǎn)記法來(lái)訪(fǎng)問(wèn)和設(shè)置,以達(dá)到兼容各種瀏覽器的效果,如:
document.getElementById("banana").class
document.getElementById("banana").style.color
document.getElementById("banana").onclick
document.getElementById("banana").class="fruit"
document.getElementById("banana").style.color="blue"
document.getElementById("banana").onclick= function (){alert("我是香蕉")}
關(guān)于Firefox下的onload問(wèn)題
function over(){
alert("頁(yè)面加載完畢")
}
正常情況下,我們賦與onload響應(yīng)函數(shù)是:
document.body.onload= over
但是在Firefox下這樣無(wú)法執(zhí)行,
所以我們都都采用下面這種形式:
window.onload=over
關(guān)于IE下TABLE無(wú)法插入新行的問(wèn)題
IE下TABLE無(wú)論是用innerHTML還是appendChild插入<tr>都沒(méi)有效果,而其他瀏覽器卻顯示正常。解決他的方法是,將<tr>加到TABLE的<tbody>元素中,如下面所示:
var row = document.createElement("tr");
var cell = document.createElement("td");
var cell_text = document.createTextNode("香蕉不吃蘋(píng)果");
cell.appendChild(cell_text);
row.appendChild(cell);
document.getElementsByTagName("tbody")[0].appendChild(row);
您可能感興趣的文章:
- JavaScript初學(xué)者建議:不要去管瀏覽器兼容
- Javascript 多瀏覽器兼容總結(jié)(實(shí)戰(zhàn)經(jīng)驗(yàn))
- JavaScript Event學(xué)習(xí)第二章 Event瀏覽器兼容性
- Javascript解決常見(jiàn)瀏覽器兼容問(wèn)題的12種方法
- Javascript 多瀏覽器兼容性問(wèn)題及解決方案
- 編寫(xiě)跨瀏覽器的javascript代碼必備[js多瀏覽器兼容寫(xiě)法]
- 多瀏覽器兼容的動(dòng)態(tài)加載 JavaScript 與 CSS
- 多瀏覽器兼容的qq圖片輪換效果javascript代碼
- javascript瀏覽器兼容教程之事件處理
相關(guān)文章
JavaScript繼承學(xué)習(xí)筆記【新手必看】
下面小編就為大家?guī)?lái)一篇JavaScript繼承學(xué)習(xí)筆記。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考2016-05-05詳解js location.href和window.open的幾種用法和區(qū)別
這篇文章主要介紹了詳解js location.href和window.open的幾種用法和區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12javascript動(dòng)態(tài)添加刪除tabs標(biāo)簽的方法
這篇文章主要介紹了javascript動(dòng)態(tài)添加刪除tabs標(biāo)簽的方法,實(shí)例分析了javascript針對(duì)tabs標(biāo)簽的動(dòng)態(tài)添加與刪除方法,涉及javascript頁(yè)面元素的操作技巧,需要的朋友可以參考下2015-07-07javascript表格控件:Chgrid,簡(jiǎn)化型
javascript表格控件:Chgrid,簡(jiǎn)化型...2007-04-04解決option標(biāo)簽selected="selected"屬性失效的問(wèn)題
下面小編就為大家?guī)?lái)一篇解決option標(biāo)簽selected="selected"屬性失效的問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,希望對(duì)大家有所幫助2017-11-11js和C# 時(shí)間日期格式轉(zhuǎn)換的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇js和C# 時(shí)間日期格式轉(zhuǎn)換的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-05-05javascript伸縮型菜單實(shí)現(xiàn)代碼
這是一款真正的JavaScript伸展收縮型菜單,鼠標(biāo)放上看一看,是不是很酷?鼠標(biāo)劃出菜單項(xiàng)的時(shí)候,背景會(huì)伸長(zhǎng)。菜單沒(méi)有加鏈接,想用的自己加,再美化一下,絕對(duì)夠個(gè)性吧。2015-11-11javascript比較兩個(gè)日期相差天數(shù)的方法
這篇文章主要介紹了javascript比較兩個(gè)日期相差天數(shù)的方法,涉及javascript針對(duì)日期的轉(zhuǎn)換與數(shù)學(xué)運(yùn)算相關(guān)技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-07-07