IE6和IE7是否支援setAttribute()函式
語法結構:
[JavaScript] 純文字檢視 複製程式碼el.setAttribute(name,value)
引數列表:
程式碼例項:
[HTML] 純文字檢視 複製程式碼<!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <title>setAttribute()函式-螞蟻部落</title> <script type="text/javascript"> window.onload=function(){ var mydiv=document.getElementById("mydiv"); mydiv.setAttribute("id","newid"); alert(mydiv.getAttribute("id")); } </script> </head> <body> <div id="mydiv"></div> </body> </html>
以上程式碼可以重新設定div的id屬性值,並且彈出新設定的id屬性值。
例項二:
[HTML] 純文字檢視 複製程式碼<!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <title>setAttribute()函式-螞蟻部落</title> <script type="text/javascript"> window.onload=function(){ var mydiv=document.getElementById("mydiv"); mydiv.setAttribute("newAttr","attrValue"); alert(mydiv.getAttribute("newAttr")); } </script> </head> <body> <div id="mydiv"></div> </body> </html>
以上程式碼可以設定div的newAttr屬性值,並且彈出此屬性值。這裡需要特別注意的是,因為div預設並不具有newAttr屬性,這個時候setAttribute()函式會首先建立此屬性,然後再給它賦值。
以上兩個程式碼例項在各主流瀏覽器中都能夠成功的執行,但這並不說明setAttribute()函式能夠相容各個瀏覽器。
再看一段程式碼例項:
[HTML] 純文字檢視 複製程式碼<!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <title>setAttribute()函式-螞蟻部落</title> <style type="text/css"> .textcolor{ font-size:18px; color:red; } </style> <script type="text/javascript"> window.onload=function(){ var mydiv=document.getElementById("mydiv"); mydiv.setAttribute("class","textcolor"); } </script> </head> <body> <div id="mydiv">螞蟻部落</div> </body> </html>
以上程式碼,在標準瀏覽器中能夠將字型大小設定為18px,字型顏色設定為紅色,但是在IE6和IE7瀏覽器中卻不能夠生效。
不過依然可以使用mydiv.getAttribute("class")獲取屬性值"textcolor"。
也就是說在IE6或者IE7瀏覽器中,setAttribute()函式可以使用,但是並不是對所有的屬性都有效。
下面就列舉一下存在上述問題的屬性:
1.class
2.for
3.cellspacing
4.cellpadding
5.tabindex
6.readonly
7.maxlength
8.rowspan
9.colspan
10.usemap
11.frameborder
12.contenteditable
13.style
為了解決上述問題就要寫一個通用的跨瀏覽器的設定元素屬性的介面方法:
[HTML] 純文字檢視 複製程式碼dom=(function(){ var fixAttr={ tabindex:'tabIndex', readonly:'readOnly', 'for':'htmlFor', 'class':'className', maxlength:'maxLength', cellspacing:'cellSpacing', cellpadding:'cellPadding', rowspan:'rowSpan', colspan:'colSpan', usemap:'useMap', frameborder:'frameBorder', contenteditable:'contentEditable' }, div=document.createElement('div'); div.setAttribute('class','t'); var supportSetAttr = div.className === 't'; return { setAttr:function(el, name, val){ el.setAttribute(supportSetAttr ? name : (fixAttr[name] || name), val); }, getAttr:function(el, name){ return el.getAttribute(supportSetAttr ? name : (fixAttr[name] || name)); } } })();
首先,標準瀏覽器直接使用原始屬性名;其次,IE6/7非以上列舉的屬性仍然用原始屬性名;最後這些特殊屬性使用fixAttr,例如class。
那麼上面的程式碼例項修改為以下形式即可:
[HTML] 純文字檢視 複製程式碼<!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="http://www.softwhy.com/" /> <title>setAttribute()函式-螞蟻部落</title> <style type="text/css"> .textcolor{ font-size:18px; color:red; } </style> <script type="text/javascript"> dom=(function(){ var fixAttr={ tabindex:'tabIndex', readonly:'readOnly', 'for':'htmlFor', 'class':'className', maxlength:'maxLength', cellspacing:'cellSpacing', cellpadding:'cellPadding', rowspan:'rowSpan', colspan:'colSpan', usemap:'useMap', frameborder:'frameBorder', contenteditable:'contentEditable' }, div=document.createElement('div'); div.setAttribute('class','t'); var supportSetAttr = div.className === 't'; return { setAttr:function(el, name, val){ el.setAttribute(supportSetAttr ? name : (fixAttr[name] || name), val); }, getAttr:function(el, name){ return el.getAttribute(supportSetAttr ? name : (fixAttr[name] || name)); } } })(); window.onload=function(){ var mydiv=document.getElementById("mydiv"); dom.setAttr(mydiv, 'class', 'textcolor'); } </script> </head> <body> <div id="mydiv">螞蟻部落</div> </body> </html>
以上程式碼可以在各主流瀏覽器中都有效,都可以將字型大小設定為18px,顏色設定為紅色。
至於style屬性可以使用el.style.color="xxx"這種形式進行相容。
相關文章
- Hive是否支援in函式Hive函式
- CSS實現文字豎排顯示(相容IE6/IE7)CSS
- dataset、setAttribute()和getAttribute() 區別
- JavaScript setAttribute()JavaScript
- bash函式應用之:判斷函式是否存在函式
- JavaScript 判斷函式是否存在JavaScript函式
- Javascript 實現 Textarea 自動伸縮,相容IE6、IE7、IE8、IE9...JavaScriptIE9
- 如何讓IE6支援min-width和max-width?
- 而井教你判斷當前Javascript執行環境是否支援async函式JavaScript函式
- POI 不支援函式XIRR函式
- openGauss 高階分析函式支援函式
- 遠端桌面函式不支援函式
- JavaScript 判斷變數是否是函式JavaScript變數函式
- Kotlin之“with”函式和“apply”函式Kotlin函式APP
- 函式防抖和函式節流函式
- 函式基礎和函式引數函式
- 指標函式 和 函式指標指標函式
- Rust中的into函式和from函式Rust函式
- StretchBlt函式和BitBlt函式的區別和用法函式
- JavaScript函式宣告和函式表示式區別JavaScript函式
- jquery1.9以上版本判斷瀏覽器是否為IE6jQuery瀏覽器
- Oracle OCP(03):字元函式、數字函式和日期函式Oracle字元函式
- JS函式節流和函式防抖JS函式
- ES6-Generator 函式 和 async 函式函式
- JavaScript中的compose函式和pipe函式JavaScript函式
- java自定義equals函式和hashCode函式Java函式
- strcpy函式和memcpy函式的區別函式memcpy
- openGauss 函式及儲存過程支援函式儲存過程
- Python技法3:匿名函式、回撥函式和高階函式Python函式
- SqlServer中將字串轉utf-8的函式、支援中文的UrlEncode函式SQLServer字串函式
- 如何使用函式指標呼叫類中的函式和普通函式函式指標
- kotlin 函式和 Lambda 表示式Kotlin函式
- ORALCE函式:LAG()和LEAD() 分析函式詳解函式
- 函式柯里化和偏函式應用函式
- # 普通函式和箭頭函式的區別函式
- Python之operator.itemgetter函式和sorted函式Python函式
- iOS-GCD常用函式和柵欄函式iOSGC函式
- 【Spark篇】---SparkSql之UDF函式和UDAF函式SparkSQL函式
- 15.3 極限函式與和函式性質函式