html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

javascript中setAttribute()函数使用方法及兼容性_javascript技巧_

[ ] 已经帮助:人解决问题

setAttribute()函数可以设置对象的属性,如果不存在此属性,则会创建此属性。ManHTML5中文学习网 - HTML5先行者学习网
ManHTML5中文学习网 - HTML5先行者学习网

语法结构:ManHTML5中文学习网 - HTML5先行者学习网

el.setAttribute(name,value)ManHTML5中文学习网 - HTML5先行者学习网
ManHTML5中文学习网 - HTML5先行者学习网

参数列表:ManHTML5中文学习网 - HTML5先行者学习网

参数 描述ManHTML5中文学习网 - HTML5先行者学习网
name 必需。规定要设置的属性名。ManHTML5中文学习网 - HTML5先行者学习网
value 必需。规定要设置的属性值。ManHTML5中文学习网 - HTML5先行者学习网
ManHTML5中文学习网 - HTML5先行者学习网

代码实例:ManHTML5中文学习网 - HTML5先行者学习网

<!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属性值。ManHTML5中文学习网 - HTML5先行者学习网
实例二:ManHTML5中文学习网 - HTML5先行者学习网

<!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()函数会首先创建此属性,然后再给它赋值。ManHTML5中文学习网 - HTML5先行者学习网

以上两个代码实例在各主流浏览器中都能够成功的执行,但这并不说明setAttribute()函数能够兼容各个浏览器。ManHTML5中文学习网 - HTML5先行者学习网

再看一段代码实例:ManHTML5中文学习网 - HTML5先行者学习网

<!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浏览器中却不能够生效。ManHTML5中文学习网 - HTML5先行者学习网

不过依然可以使用mydiv.getAttribute("class")获取属性值"textcolor"。ManHTML5中文学习网 - HTML5先行者学习网

也就是说在IE6或者IE7浏览器中,setAttribute()函数可以使用,但是并不是对所有的属性都有效。ManHTML5中文学习网 - HTML5先行者学习网

下面就列举一下存在上述问题的属性:ManHTML5中文学习网 - HTML5先行者学习网

1.classManHTML5中文学习网 - HTML5先行者学习网

2.forManHTML5中文学习网 - HTML5先行者学习网

3.cellspacingManHTML5中文学习网 - HTML5先行者学习网

4.cellpaddingManHTML5中文学习网 - HTML5先行者学习网

5.tabindexManHTML5中文学习网 - HTML5先行者学习网

6.readonlyManHTML5中文学习网 - HTML5先行者学习网

7.maxlengthManHTML5中文学习网 - HTML5先行者学习网

8.rowspanManHTML5中文学习网 - HTML5先行者学习网

9.colspanManHTML5中文学习网 - HTML5先行者学习网

10.usemapManHTML5中文学习网 - HTML5先行者学习网

11.frameborderManHTML5中文学习网 - HTML5先行者学习网

12.contenteditableManHTML5中文学习网 - HTML5先行者学习网

13.styleManHTML5中文学习网 - HTML5先行者学习网

为了解决上述问题就要写一个通用的跨浏览器的设置元素属性的接口方法:ManHTML5中文学习网 - HTML5先行者学习网

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。ManHTML5中文学习网 - HTML5先行者学习网

那么上面的代码实例修改为以下形式即可:ManHTML5中文学习网 - HTML5先行者学习网

<!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,颜色设置为红色。ManHTML5中文学习网 - HTML5先行者学习网
至于style属性可以使用el.style.color="xxx"这种形式进行兼容。ManHTML5中文学习网 - HTML5先行者学习网

以上所述就是本文的全部内容了,希望大家能够喜欢。ManHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助