麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > 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"這種形式進行兼容。

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美成人精品不卡视频在线观看 | 欧美日韩国产综合网 | 国产毛片aaa一区二区三区视频 | 一级大片一级一大片 | 国产一级aa大片毛片 | 国产三级三级三级三级 | 国产无遮挡一级毛片 | 国产免费一区二区三区在线能观看 | 欧美激情精品久久久久久黑人 | av电影院在线观看 | 羞羞视频免费网站含羞草 | 毛片一区二区三区四区 | 久久久久久久久久久久久九 | 91精品国产综合久久婷婷香 | 手机在线看片国产 | 七首小情歌泰剧在线播放 | 久久久新| 国产精品美女一区二区 | 成年免费视频黄网站在线观看 | 免费黄色大片网站 | 黄色99视频 | 91九色精品 | 日本中文字幕电影在线观看 | 毛片大全免费看 | 在线播放免费人成毛片乱码 | 一级全毛片 | 一区二区视频在线看 | 久久国产精品久久久久久久久久 | 国产1区在线| 毛片大全免费 | 日韩激情一区二区三区 | 国产精品视频中文字幕 | 亚洲国产一区二区三区 | 久草在线资源福利站 | 久久久免费观看完整版 | 玖玖精品视频在线 | 国产精品午夜小视频观看 | 亚洲欧洲av在线 | 精品一区二区三区日本 | 久久精品视频网站 | 污片在线观看视频 |