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


Posted in Javascript onJuly 19, 2015

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"这种形式进行兼容。

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
jQuery 版元素拖拽原型代码
Apr 25 Javascript
Javascript 键盘事件的组合使用实现代码
May 04 Javascript
jquery如何改变html标签的样式(两种实现方法)
Jan 16 Javascript
JS动态获取当前时间,并写到特定的区域
May 03 Javascript
用JavaScript实现使用鼠标画线的示例代码
Aug 19 Javascript
jquery带下拉菜单和焦点图代码分享
Aug 24 Javascript
javascript中for/in循环及使用技巧
Sep 01 Javascript
jQuery插件扩展测试实例
Jun 21 Javascript
Angular.JS中的this指向详解
May 17 Javascript
Angular5升级RxJS到5.5.3报错:EmptyError: no elements in sequence的解决方法
Apr 09 Javascript
Nuxt.js开启SSR渲染的教程详解
Nov 30 Javascript
解决vue自定义组件@click点击失效问题
Apr 30 Vue.js
jQuery的position()方法详解
Jul 19 #Javascript
ExtJs动态生成treepanel的Json格式
Jul 19 #Javascript
javascript中mouseover、mouseout使用详解
Jul 19 #Javascript
javascript实现的简单计时器
Jul 19 #Javascript
javascript中setInterval的用法
Jul 19 #Javascript
js中跨域方法原理详解
Jul 19 #Javascript
javascript获取网页宽高方法汇总
Jul 19 #Javascript
You might like
PHP.MVC的模板标签系统(一)
2006/09/05 PHP
PHP 服务器配置(使用Apache及IIS两种方法)
2009/06/01 PHP
php面向对象全攻略 (十二) 抽象方法和抽象类
2009/09/30 PHP
LotusPhp笔记之:基于ObjectUtil组件的使用分析
2013/05/06 PHP
php.ini修改php上传文件大小限制的方法详解
2013/06/17 PHP
smarty表格换行实例
2014/12/15 PHP
php版微信js-sdk支付接口类用法示例
2016/10/12 PHP
php 读写json文件及修改json的方法
2018/03/07 PHP
javascript图片相似度算法实现 js实现直方图和向量算法
2014/01/14 Javascript
js实现的点击div区域外隐藏div区域
2014/06/30 Javascript
自编jQuery插件实现模拟alert和confirm
2014/09/01 Javascript
jquery实现点击变换导航样式的方法
2015/08/31 Javascript
jquery实现二级导航下拉菜单效果
2015/12/18 Javascript
一种Javascript解释ajax返回的json的好方法(推荐)
2016/06/02 Javascript
NodeJS远程代码执行
2016/08/28 NodeJs
微信小程序 Flex布局详解
2016/10/09 Javascript
bootstrap table表格客户端分页实例
2017/08/07 Javascript
vue实现压缩图片预览并上传功能(promise封装)
2019/01/10 Javascript
js实现图片3D轮播效果
2019/09/21 Javascript
JavaScript中reduce()的5个基本用法示例
2020/07/19 Javascript
Python 元类使用说明
2009/12/18 Python
python和shell实现的校验IP地址合法性脚本分享
2014/10/23 Python
python 安装virtualenv和virtualenvwrapper的方法
2017/01/13 Python
python常见字符串处理函数与用法汇总
2019/10/30 Python
如何在mac环境中用python处理protobuf
2019/12/25 Python
用sleep间隔进行python反爬虫的实例讲解
2020/11/30 Python
HTML5 textarea高度自适应的两种方案
2020/04/08 HTML / CSS
如何写出高性能的JSP和Servlet
2013/01/22 面试题
纬创Java面试题笔试题
2014/10/02 面试题
关于赌博的检讨书
2014/01/08 职场文书
公益广告语集锦
2014/03/13 职场文书
村当支部个人对照检查材料思想汇报
2014/10/06 职场文书
公司更名通知函
2015/04/24 职场文书
血轮眼轮回眼特效 html+css
2021/03/31 HTML / CSS
Python下opencv库的安装过程及问题汇总
2021/06/11 Python
Python docx库删除复制paragraph及行高设置图片插入示例
2022/07/23 Python