html 5 data-* (dataset) 属性和 jquery data方法比较
一些文章在介绍html 5 data-* (dataset)属性时,会提到jquery的data方法,认为data方法能够很好的利用html 5的这个特性。但实际上,二者的兼容性是很差的。下面给出一段测试代码:
<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
<div id="e" data-v="origin"></div>
<script>
var log = function(msg){console.log(msg);};
var print = function(){
log("jquery.data : " + je.data("v"));
log("native dataset : " + ne.dataset["v"]);
log("--");
} var je = $("#e");
var ne = document.getElementById("e"); log("origin value");
print(); log("set with native dataset");
ne.dataset["v"] = "native";
print();
/* reset */ ne.dataset["v"] = "origin"; log("set with jquery data");
je.data("v", "jquery");
print();
/* reset */ je.data("v", "origin");
</script>
在console的输出结果如下:
origin value
jquery.data : origin
native dataset : origin
--
set with native dataset
jquery.data : origin
native dataset : native
--
set with jquery data
jquery.data : jquery
native dataset : origin
--
测试的最开始,data()和dataset从html中读取的data-v值是一致的,但是当对值进行修改时,结果就不一样了。另外,通过审查元素可以发现:通过jquery.data方法设置data属性不会修改DOM;而通过dataset方法则会同步修改DOM。或许可以认为,jquery data的实现方式没有遵循html 5标准。
鉴于这种情况的存在,在一个项目中应该不要混用两种方法。
html 5 data-* (dataset) 属性和 jquery data方法比较的更多相关文章
- 转载 JQuery中attr属性和JQuery.data()学习
		
转载原地址: http://www.cnblogs.com/yeminglong/p/5405745.html 用html直接data-key来存放,key必须全部小写. <div data-m ...
 - JQuery中attr属性和jQuery.data()学习笔记
		
用html直接data-key来存放,key必须全部小写. <div data-mydata="123"></div> consoloe.log($(&qu ...
 - jQuery源码解读 - 数据缓存系统:jQuery.data
		
jQuery在1.2后引入jQuery.data(数据缓存系统),主要的作用是让一组自定义的数据可以DOM元素相关联——浅显的说:就是让一个对象和一组数据一对一的关联. 一组和Element相关的数据 ...
 - HTML5 自定义属性 data-* 和 jQuery.data 详解
		
新的HTML5标准允许你在普通的元素标签里,嵌入类似data-*的属性,来实现一些简单数据的存取.它的数量不受限制,并且也能由javascript动态修改,也支持CSS选择器进行样式设置.这使得dat ...
 - 读jQuery源码 jQuery.data
		
var rbrace = /(?:\{[\s\S]*\}|\[[\s\S]*\])$/, rmultiDash = /([A-Z])/g; function internalData( elem, n ...
 - jQuery.data() 的实现方式,jQuery16018518865841457738的由来,jQuery后边一串数字的由来
		
原文地址: http://xxing22657-yahoo-com-cn.iteye.com/blog/1042440 jQuery.data() 的实现方式 jQuery.data() 的作用是为普 ...
 - jQuery对象数据缓存Cache原理及jQuery.data详解
		
网上有很多教你怎么使用jQuery.data(..)来实现数据缓存,但有两个用户经常使用的data([key],[value])和jQuery.data(element,[key],[value])几 ...
 - jQuery.data() 存储数据
		
jQuery.data() 的实现方式 jQuery.data() 的作用是为普通对象或 DOM Element 附加数据. 以下将分三个部分分析事实上现方式: 1. 用name和value为对象附加 ...
 - jquery data的用法
		
jquery data和 jquery attr, js getAttribute 有着本质的区别,并且无法用$(el).data('property')的方法,去获取$(el).attr('data ...
 
随机推荐
- java学习笔记 --- IO流小结
			
IO流 |--字节流 |--字节输入流 InputStream int read():一次读取一个字节 int read(byte[] bys):一次读取一个字节数 ...
 - nyoj-155-求高精度幂(java大数)
			
题目链接 import java.util.*; import java.math.*; public class Main{ public static void main(String[] arg ...
 - BEC  listen and translation exercise 6
			
能听懂自己的录音,说明发音还行,可惜听不懂... Another problem is that the members of the Biramichi fishing cooperative ar ...
 - 使用自定义端口连接SQL Server 2008的方法
			
版权声明:本文为博主原创文章,未经博主允许不得转载. 使用过SQL Server的人大多都知道,SQL Server服务器默认监听的端口号是1433,但是我今天遇到的问题是我的机器上有三个数据库实例, ...
 - Makefile中的路径
			
使用 $(shell pwd) 可以在Makefile中指定为当前Makefile所在目录的路径
 - linux swap交换分区说明/管理
			
https://coolnull.com/3699.html 一.SWAP说明1.1 SWAP概述当系统的物理内存不够用的时候,就需要将物理内存中的一部分空间释放出来,以供当前运行的程序使用.那些被释 ...
 - 蓝桥杯 基础练习 BASIC-19 完美的代价
			
基础练习 完美的代价 时间限制:1.0s 内存限制:512.0MB 问题描述 回文串,是一种特殊的字符串,它从左往右读和从右往左读是一样的.小龙龙认为回文串才是完美的.现在给你一个串,它不一定 ...
 - Java-API-Package:org.springframework.stereotype
			
ylbtech-Java-API-Package:org.springframework.stereotype 1.返回顶部 1. @NonNullApi @NonNullFields Package ...
 - Java-API:java.text.SimpleDateFormat
			
ylbtech-Java-API:java.text.SimpleDateFormat 1.返回顶部 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 0. https://do ...
 - Java程序开发中的简单内存分析
			
首先说明内存总体分为了4个部分, 包括 1.stack segment (栈区存储基本数据类型的局部变量,对象的引用名) 2.heap segment(堆区,一般用于存储java中new 出来的对象) ...