html5的自定义data属性相信大家都不会陌生,有了它你可以绑定所需的数据到指定元素上。然后通过jquery设置、获取数据,简直开心的不行啊。
想到设置、获取元素属性值,大家一定首先想到了jquery的.attr()方法,但是你一定知道jquery还有个.data()的方法。本人以前一直萌(傻)萌(傻)哒(的)以为这两个方法在处理data属性过程中实现的效果是一样的,只不过.data()方法官方更推荐使用(看名字就感觉人家是正规军)。但后来本人在做项目的过程中发现,这两种方法处理data属性并不相同(想想也是,要是一样,还搞个data干毛)。废话少说,下面来点干的:

 <html>
<head>
<meta charset="UTF-8">
<script src="https://code.jquery.com/jquery-1.11.3.min.js"></script> <script>
$(function(){
  $("#btn1").click(function(){
    $("div").attr("data-my-value", "使用attr改变的数据");
    $("p").text("使用attr设置数据成功");
  });
  $("#btn2").click(function(){
    $("div").data("myValue", "使用data改变的数据");
    $("p").text("使用data设置数据成功");
  });
  $("#btn3").click(function(){
    var v = $("div").attr("data-my-value");
    $("p").text("使用attr获取数据:"+v);
  });
  $("#btn4").click(function(){
    var v = $("div").data("myValue");
    $("p").text("使用data获取数据:"+v);
  });
  $("#btn5").click(function(){
    $("div").data("person", {age:12, name:"wang"});
    $("p").text("使用data增加属性person成功");
  });
  $("#btn6").click(function(){
    console.log($("div").data());
  });
});
</script>
</head> <body>
<button id="btn1">1.使用attr设置</button>
<button id="btn2">2.使用data设置</button>
<button id="btn3">3.使用attr获取</button>
<button id="btn4">4.使用data获取</button>
<button id="btn5">5.使用data增加person属性</button>
<button id="btn6">6.控制台打印data</button>
<div data-my-value="服务器渲染数据"></div>
<p></p>
</body>
</html>

这段代码是不是简单的不行了,下面我们用这段代码说明一下.attr()和.data()在处理data属性时的不同之处:
这里我们给div增加了“data-my-value”属性,很多时候data属性的数据会在页面加载时由服务器获取,这里我们通过构建DOM时将“data-my-value”赋值为“服务器渲染数据”的方法模拟服务器数据渲染。

  1. 首先我们点击3、4按钮,发现获取的数据均为“服务器渲染数据”。好像没什么不同,别着急,继续看。
  2. 接下来我们打开浏览器调试工具,注意div元素,点击1按钮,div的“data-my-value”变为“使用attr改变的数据”,然后点击3按钮,获取的数据为“使用attr改变的数据”,点击4按钮,获取的数据为“服务器渲染数据”。通过调试器我们发现元素的“data-my-value”属性为“使用attr改变的数据”,为什么通过.data()方法获取的数据依旧是“服务器渲染数据”?我们再来看看下面的操作。
  3. 点击2按钮,通过调试器我们发现div的“data-my-value”属性数据没有发生变化,然后我们点击3按钮,获取的数据为“使用attr改变的数据”,点击4按钮,获取的数据为“使用data改变的数据”。what?

遇到问题,肯定要首先查官方手册了,通过查询手册和在Stack Overflow查资料我总结了如下几点(有不对的地方欢迎大家指正):

  1. jquery通过attr直观的设置、获取data属性值,data虽然为自定义属性,但是attr处理它与处理标准元素相同。
  2. jquery的data方法是将数据存储在与元素关联的对象中,并不是改变元素的属性值,通过.data()(不加任何参数)可以获得该对象。点击上面demo中的按钮6可以在控制台查看该对象。
  3. 有一点需要注意,当页面加载时,jquery会默认将data属性的数据加入到这个关联的对象中,后面可以通过data(key,value)方法修改数据,也可以添加新的数据或对象,当然添加的新data属性不会在DOM有所体现(通过点击按钮5增加新属性,点击6查看)。

总之,.attr()方法处理data属性与标准属性相同;使用.data()方法的整个过程中,jquery一直操作的是这个与元素关联的对象,和DOM中元素本身的属性无关。

文中有不对的地方欢迎大家多多指正。

参考:
http://api.jquery.com/attr/
https://api.jquery.com/data/
https://stackoverflow.com/questions/5309926/how-to-get-the-data-id-attribute
https://stackoverflow.com/questions/7261619/jquery-data-vs-attr

jquery data属性 attr vs data的更多相关文章

  1. 关于jQuery中的attr和data问题

    今天在使用data获取属性并且赋值时遇到一个小问题,写下来防止以后再跳坑. 在使用jQuery获取自定义属性值时,我们习惯用 $(selector).attr('data-value'); jQuer ...

  2. jQuery元素属性attr设置多个键值或函数 删除属性removeAttr

    $("Element").attr(name) '取得第一个匹配的属性值,比如$("img").attr("src") $("El ...

  3. jquery操作属性 attr()和 prop()兼容性问题

    jquery1.6中新加了一个方法prop(),一直没用过它,官方解释只有一句话:获取在匹配的元素集中的第一个元素的属性值. 大家都知道有的浏览器只要写disabled,checked就可以了,而有的 ...

  4. 【七】jquery之属性attr、 removeAttr、prop[全选全不选及反选]

    全选全不选 界面: 代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> ...

  5. HTML 5:你必须知道的data属性

    原文:All You Need to Know About the HTML5 Data Attribute 译文:你必须知道HTML 5 的Data属性 译者:dwqs HTML 5的Data属性可 ...

  6. html 5实用特性之data属性

    HTML 5之前,我们必须依赖于class和rel属性来存储需要在网站中使用的数据片段,这种做法有时会在网站的外观和实用性之间产生冲突.而HTML 5 Data属性的存在就能很好满足需要. HTML5 ...

  7. HTML data属性简介以及低版本浏览器兼容算法

    实例 使用 data-* 属性来嵌入自定义数据: <ul> <li data-animal-type="bird">Owl</li> <l ...

  8. data属性

    本框架内置组件以及部分插件可以通过data属性来初始化并使用,通常通过data-toggle来调用API(toggle是触发器的意思,例如我们创建一个navtab标签可以通过为a的data-toggl ...

  9. 对比jquery获取属性的方法props、attr、data

    1.attr,prop 对于HTML元素本身就带有的固有属性,在处理时,使用prop方法.对于自定义的属性是取不到的: 对于HTML元素我们自己自定义的DOM属性,在处理时,使用attr方法. 2.a ...

随机推荐

  1. Codeforces Round #259 (Div. 1)A(公式)

    传送门 题意 给出m个面的骰子扔n次,取最大值,求期望 分析 暴力算会有重复,而且复杂度不对. 考虑m个面扔n次得到m的概率,发现只要减去(m-1)个面扔n次得到m-1的概率即可,给出example说 ...

  2. Excel学习 -- 函数基础

    Excel函数基础 1. 单元格是函数的作用对象:    2. 函数由等号.函数表达式.操作符.参数.返回值五部分组成:    3. 商业智能报表中使用的常用函数分类:数学函数.文本函数.逻辑函数.查 ...

  3. mybatis 批量insert,update报错 The error occurred while setting parameters

    数据脚本执行正常,但是报错,搜索关键信息 The error occurred while setting parameters ,发现了解决帖子: http://blog.csdn.net/jing ...

  4. 进击的Python【第十二章】:mysql介绍与简单操作,sqlachemy介绍与简单应用

    进击的Python[第十二章]:mysql介绍与简单操作,sqlachemy介绍与简单应用 一.数据库介绍 什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数 ...

  5. _bzoj2038 [2009国家集训队]小Z的袜子(hose)【莫队】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2038 裸的莫队,注意要先移动右端点再移动左端点. #include <cstdio&g ...

  6. [USACO 2011 Nov Gold] Cow Steeplechase【二分图】

    传送门:http://www.usaco.org/index.php?page=viewproblem2&cpid=93 很容易发现,这是一个二分图的模型.竖直线是X集,水平线是Y集,若某条竖 ...

  7. COT2 - Count on a tree II(树上莫队)

    COT2 - Count on a tree II You are given a tree with N nodes. The tree nodes are numbered from 1 to N ...

  8. Stamps ans Envelope Sive UVA - 242

    ( ||{集合x}表示x中元素1||x中元素2||...||x的最后一个元素||(a,b)表示a||b) ans[i][j][k]表示考虑前i种邮票时取j个邮票能否得到面值kans[i][j][k]= ...

  9. Oracle10g修改数据库字符集

    Oracle10g修改字符集记录: 版本:Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - 64bit Production 参考 ...

  10. LinkedList,SortedList 基本用法

    LinkedList类是双向列表,列表中的每个节点都包含了对前一个和后一个元素的引用. LinkedList<int> ma = new LinkedList<int>(); ...