Jquery中.attr()和.data()的区别

jQuery中.attr()与.data()的区别
本文通过实例讲解了jQuery中的$.attr()和$.data()方法的区别,重点阐述了两者在获取和设置DOM属性值时的不同行为及应用场景。
本文和大家分享的主要是jquery .attr() .data()相关内容,一起来看看吧,希望对大家 学习jquery有所帮助。
  $.attr() $.data() 本质上属于  DOM属性    Jquery对象属性  的区别。
   Jquery对象属性和DOM属性
  一个简单的例子
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>Jquery .attr .data 的区别 </title>
    </head>
    <body>
        <p id="app" data-foo="hello"></p>
    </body>
    <script type="text/javascript" src="http://cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>
    <script type="text/javascript">
        var getAttr1 = $('#app').attr('data-foo');
        var getData1 = $('#app').data('foo');
        console.log('getAttr1: ' + getAttr1); //hello
        console.log('getData1: ' + getData1); //hello
        $('#app').attr('data-foo', 'world'); //$.attr  设置 DOM 元素属性值
        var getAttr2 = $('#app').attr('data-foo');
        var getData2 = $('#app').data('foo');
        console.log('getAttr2: ' + getAttr2); //world
        console.log('getData2: ' + getData2); //*** hello ***
        $('#app').data('foo', 'WORLD'); //$.data  设置 DOM node 属性值
        var getAttr3 = $('#app').attr('data-foo');
        var getData3 = $('#app').data('foo');
        console.log('getAttr3: ' + getAttr3); //world
        console.log('getData3: ' + getData3); //*** WORLD ***
    </script>
</html>
  · $.attr() 每次都从 DOM  元素  中取属性的值,即和视图中标签内的属性值保持一致。
  · $.attr('data-foo') 会从标签内获得 data-foo 属性值;
  · $.attr('data-foo', 'world') 会将字符串 'world' 塞到标签的 'data-foo' 属性中;
  · $.data() 是从  Jquery对象  中取值,由于对象属性值保存在内存中,因此可能和视图里的属性值不一致的情况。
  · $.data('foo') 会从  Jquery对象  内获得foo 的属性值,不是从标签内获得 data-foo 属性值;
  · $.data('foo', 'world') 会将字符串 'world' 塞到  Jquery对象  'foo' 属性中,而不是塞到视图标签的 data-foo 属性中。
  结合上面代码和解释,大家应该能够理解两者的区别。
   小结
  所以$.attr() $.data() 应避免混合用,也就是应该尽量避免如下两种情况的出现:
  1.  通过 $.attr() 来进行 set 属性,然后通过 $.data() 进行 get 属性值;
  2.  通过 $.data() 来进行 set 属性,然后通过 $.attr() 进行 get 属性值。
  同时从性能的角度来说,建议使用$.data() 来进行 set get 操作,因为它仅仅修改的  Jquey对象 的属性值,不会引起额外的DOM 操作。
来源: 体验盒子
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值