亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javascript中setAttribute()函數使用方法及兼容性

2019-11-20 12:01:19
字體:
來源:轉載
供稿:網友

setAttribute()函數可以設置對象的屬性,如果不存在此屬性,則會創建此屬性。

語法結構:

el.setAttribute(name,value)

參數列表:

參數 描述
name 必需。規定要設置的屬性名。
value 必需。規定要設置的屬性值。

代碼實例:

<!DOCTYPE html><html><head><meta charset=" utf-8"> <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屬性值。
實例二:

<!DOCTYPE html><html><head><meta charset=" utf-8"><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()函數能夠兼容各個瀏覽器。

再看一段代碼實例:

<!DOCTYPE html><html><head><meta charset=" utf-8"><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

為了解決上述問題就要寫一個通用的跨瀏覽器的設置元素屬性的接口方法:

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。

那么上面的代碼實例修改為以下形式即可:

<!DOCTYPE html><html><head><meta charset=" utf-8"> <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> </body> </html>

以上代碼可以在各主流瀏覽器中都有效,都可以將字體大小設置為18px,顏色設置為紅色。
至于style屬性可以使用el.style.color="xxx"這種形式進行兼容。

以上所述就是本文的全部內容了,希望大家能夠喜歡。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美亚洲成人xxx| 日韩电影大全免费观看2023年上| 国产又爽又黄的激情精品视频| 久久国产精品久久久久久| 91精品国产九九九久久久亚洲| 欧美日韩国产中文精品字幕自在自线| 成人黄色免费网站在线观看| 成人春色激情网| 久久影视电视剧免费网站清宫辞电视| 日韩一区二区福利| 欧美性xxxxxx| 国产在线精品自拍| 97人人做人人爱| 亚洲成人黄色在线| 日韩视频中文字幕| 久久久久久久久国产| 亚洲欧美国产视频| 成人性生交大片免费看小说| 91精品久久久久久久久中文字幕| 成人精品在线观看| 亚洲欧洲在线看| 81精品国产乱码久久久久久| zzjj国产精品一区二区| 国产成人精品在线| 欧美成人中文字幕在线| 精品国产拍在线观看| 成人黄色影片在线| 亚洲成人黄色网| 亚洲一区亚洲二区亚洲三区| 欧洲成人免费视频| 国产精品都在这里| 亚洲影院高清在线| 国产精品久久久久久影视| 亚洲国产精彩中文乱码av| 久久综合免费视频影院| 一个色综合导航| 97国产一区二区精品久久呦| 欧美激情视频在线观看| 亚洲欧美精品一区二区| 亚洲天堂色网站| 国自在线精品视频| 欧美成人精品在线观看| 国产精品亚洲精品| 日韩精品视频在线| 青草青草久热精品视频在线观看| 奇米四色中文综合久久| 国产精品一区二区电影| 欧美裸体xxxx极品少妇软件| 精品久久中文字幕| 欧美第一黄色网| 欧美激情欧美狂野欧美精品| 国产日韩精品一区二区| 欧美精品videos| 亚洲最大的免费| 日韩欧美有码在线| 欧美黑人巨大精品一区二区| 欧美日韩亚洲天堂| 国产精品久久久久久婷婷天堂| 国产精品精品视频一区二区三区| 538国产精品一区二区在线| 亚洲人成网站免费播放| 日本三级韩国三级久久| 亚洲欧美日韩精品久久亚洲区| 81精品国产乱码久久久久久| 亚洲福利在线视频| 中文字幕综合在线| 日韩视频亚洲视频| 影音先锋日韩有码| 97视频人免费观看| 久久亚洲精品中文字幕冲田杏梨| 久久中国妇女中文字幕| 亚洲福利视频网站| 亚洲精品综合久久中文字幕| 日韩av电影免费观看高清| 91沈先生在线观看| 国产精品久久久久av| 日韩视频免费观看| 日本久久久久亚洲中字幕| 久久综合伊人77777尤物| 97精品一区二区视频在线观看| 国产99在线|中文| 欧美久久精品一级黑人c片| 欧美性猛交xxxx富婆弯腰| 中文字幕精品www乱入免费视频| 亚洲最大在线视频| 亚洲成av人片在线观看香蕉| 国产日产亚洲精品| 亚洲视频欧洲视频| 亚洲欧美日韩一区二区在线| 精品一区二区亚洲| 欧美日本高清一区| 亚洲精品在线91| 国产精品视频在线观看| 一级做a爰片久久毛片美女图片| 97成人精品视频在线观看| 国产美女精彩久久| 欧美精品在线免费| 亚洲电影成人av99爱色| 久久999免费视频| 精品视频一区在线视频| 国产原创欧美精品| 欧美性受xxx| 欧美激情亚洲自拍| 国产精品91久久久| www.亚洲免费视频| 欧美成人精品在线| 国产成人精品国内自产拍免费看| 久久久久久69| 亚洲欧美日韩天堂| 国产精品成人aaaaa网站| 不卡在线观看电视剧完整版| 国产精品伦子伦免费视频| 中国日韩欧美久久久久久久久| 夜夜狂射影院欧美极品| 欧美日韩免费观看中文| 久久国产精品亚洲| 成人xvideos免费视频| 在线观看欧美日韩国产| 亚洲午夜av久久乱码| 国产69久久精品成人看| 97视频免费在线看| 成人在线中文字幕| 国产成人精品最新| 黑人巨大精品欧美一区免费视频| 国产精品入口福利| 国产精品网红福利| 国产精品久久99久久| 亚洲伊人一本大道中文字幕| 国产精品欧美日韩久久| 一区二区福利视频| 91美女片黄在线观| 日韩免费视频在线观看| 久热精品视频在线免费观看| 久久久久北条麻妃免费看| 日韩成人在线电影网| 少妇av一区二区三区| 国产精品露脸av在线| 国产日本欧美视频| 亚洲第一中文字幕在线观看| 国产精品jvid在线观看蜜臀| 亚洲tv在线观看| 久久精品国产精品亚洲| 日韩精品中文字幕在线观看| 亚洲精品国精品久久99热一| 91热福利电影| 亚洲少妇中文在线| 国产精品毛片a∨一区二区三区|国| 国产精品av电影| 国产成人精品免费视频| 8x拔播拔播x8国产精品| 欧美日韩免费看| 久久99久久99精品免观看粉嫩| 神马久久桃色视频| 久久精品视频中文字幕| 成人免费黄色网| 国产视频精品xxxx| 国产精品爽爽ⅴa在线观看| 亚洲国产美女久久久久| 国产精品久久色| 亚洲色图50p| 曰本色欧美视频在线| 国产精品久久久999| 成人久久18免费网站图片| 国产欧美在线看|