解惑,什么是data-attribute ?
在接触 Web前端开发的一段时间,有时会去看Google或者百度的源代码,有某些地方定义了 data-key ,这种语法
但是如果你直接去 Google data-key 或 data-item 可能又查不到这个属性,到底这是哪个属性呢?
通过查资料我发现,利用 HTML 5,可以为元素添加data-*,从而存储自定义信息。其中*是可以自定义的部分。例如:
<article id='tu' data-category="Web Development" data-author="1"> ... </article>
这也就是为什么去 Google data-size 或 data-item 会找不到东西的原因,因为那是网页工程师自己定义出来的字词
既然我们存了这些自定义的数据属性,那么该怎么取这个值呢 ?
通过 JavaScript获取属性的值
通过 JavaScript 访问自定义的信息有两种方式:getAttribute()方法和dataset属性
getAttribute 方法
这就是经典的取得一个元素属性的方式,和以前一样。
document.getElementById('tu').getAttribute('data-category'); // "Web Development"
dataset 方法
这是 HTML 5 新增的方法,可以更方便的读取所有的 data 信息。
var article = document.getElementById('tu');
var data = article.dataset;
alert(data.category); // "Web Development"
alert(data.author); // 1
通过CSS获取属性的值
使用 attr
article::before {
    content: attr(data-category);
}
使用属性选择器
article[data-author='1'] {
    border-width: 1px;
}
合理的使用数据属性, 可以帮助我们在网页开发的时候更有效率或做出更多不同的效果
参考
解惑,什么是data-attribute ?的更多相关文章
- data属性(The Data Attribute)
		
HTML片段 <div id="myDiv" data-custom-attr="My Value"> 巴拉巴拉,lady 嘎嘎 </div& ...
 - HTML 5:你必须知道的data属性
		
原文:All You Need to Know About the HTML5 Data Attribute 译文:你必须知道HTML 5 的Data属性 译者:dwqs HTML 5的Data属性可 ...
 - Python高手之路【三】python基础之函数
		
基本数据类型补充: set 是一个无序且不重复的元素集合 class set(object): """ set() -> new empty set object ...
 - Python基础(三)
		
本章内容: 深浅拷贝 函数(全局与局部变量) 内置函数 文件处理 三元运算 lambda 表达式 递归(斐波那契数列) 冒泡排序 深浅拷贝 一.数字和字符串 对于 数字 和 字符串 而言,赋值.浅拷贝 ...
 - PYTHON文件操作(二)
		
class file(object) def close(self): # real signature unknown; restored from __doc__ 关闭文件 "" ...
 - Python之路【第五篇】python基础 之初识函数(一)和文件管理
		
转载请注明出处http://www.cnblogs.com/wupeiqi/articles/5453708.html 函数 一.背景 ...
 - python基础之文件处理
		
读和写文件 读写文件是最常见的IO操作.Python内置了读写文件的函数,用法和C是兼容的. 读写文件前,我们先必须了解一下,在磁盘上读写文件的功能都是由操作系统提供的,现代操作系统不允许普通的程序直 ...
 - Python开发【第三篇】:Python基本之文件操作
		
Python基本之文本操作 一.初识文本的基本操作 在python中打开文件有两种方式,即:open(...) 和 file(...) ,本质上前者在内部会调用后者来进行文件操作,推荐使用 open ...
 - You Don't Need jQuery
		
前端发展很快,现代浏览器原生 API 已经足够好用.我们并不需要为了操作 DOM.Event 等再学习一下 jQuery 的 API.同时由于 React.Angular.Vue 等框架的流行,直接操 ...
 - oneuijs/You-Dont-Need-jQuery
		
oneuijs/You-Dont-Need-jQuery https://github.com/oneuijs/You-Dont-Need-jQuery/blob/master/README.zh- ...
 
随机推荐
- Nginx详细介绍
			
1.Nginx是什么? Nginx就是反向代理服务器. 首先我们先来看看什么是代理服务器,代理服务器一般是指局域网内部的机器通过代理服务发送请求到互联网上的服务器,代理服务器一般作用于客户端.比如Go ...
 - 一张PDF了解JDK9 GC调优秘籍-附PDF下载
			
目录 简介 Oracle中的文档 JDK9中JVM参数的变化 废弃的JVM选项 不推荐(Deprecated)的JVM选项 被删除的JVM参数 JDK9的新特性Application Class Da ...
 - 深入理解JVM(③)Java模块化系统
			
前言 JDK9引入的Java模块化系统(Java Platform Module System ,JPMS)是 对Java技术的一次重要升级,除了像之前JAR包哪有充当代码的容器之外,还包括: 依赖其 ...
 - crm项目开发之架构设计
			
CRM customer relationship management 客户管理系统 1. 干什么用的? 管理客户 维护客户关系 2. 谁去使用? 销售 班主任 项目经理 3. 需求: 1. 登录 ...
 - 一个ioc例子jdk和spring版本导致问题
			
今天橘子松在做一个简单例子的时候,出现bug让我久久找了半小时... 天啊 不会吧 错误如下: java.lang.NoSuchMethodError: org.springframework.a ...
 - swiper的自适应高度问题
			
#swiper的自适应高度问题  众所周知,swiper组件的元素swiper-item是设置了绝对定位的,所以里面的内容是无法撑开swiper的,并且给swiper盒子设置overflow:vis ...
 - CodeForces 1293 C NEKO's Maze Game
			
[题目链接] [题目大意] 有一个2 ∗ n的地图,小女孩从(1,1)想移动到(2,n) 有q次询问,每次询问更改一个格子状态(是否可以通过) 只能上下左右移动而不能斜着移动,问每次操作后,是否可以移 ...
 - 字符串的排列(剑指offer-27)
			
题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 输入描述: 输 ...
 - 阿里云上安装启动nginx 以及在个人电脑上通过公网ip访问遇到的问题
			
1.安装依赖包 //一键安装上面四个依赖 yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel 2.下载并解压安装包 ...
 - web网页动态分享facebook和twitter
			
介绍 facebook分享 http://www.facebook.com/sharer.php?t=${text}u=encodeURIComponent('静态html') twitter分享 h ...