自己定义属性data-*

说起这个属性,事实上如今非经常见了;怎么说呢,由于在一些框架都能看到他的身影!!!

比方Jquery mobile,里面非常频繁的使用了这个属性;

这个属性是哪里来的….当然是尾随最新的H5一起出来的…..

兼容性在PC端仅仅能呢说一般般(眼下.比較老式浏览器居多),,手机端支持还是比較OK的;

虽说是自己定义属性,可是还是有一定的规格的,,比方前缀必须是data-[自己定义属性];

比方

    <div data-id="id"></div>

这货有什么用呢?用来操作数据的居多,比方给一款游戏弄一些额外的信息!!(data-level,data-score);

而操作数据一般有两种方式(原生JS和JQ):

1. 利用 getAttribute、setAttribute 存取 data[原生JS操作]

2. 利用 dataset API 存取 dataset [这样的能够直接忽略data-,相似对象直接訪问属性,也是JS操作的]

3. jQuery使用attr 和 data 依次等同于上面两种

在网上发现了一篇解说比較具体的操作数据,能够瞄瞄

传送门: http://blog.netsh.org/posts/html-data-jquery_1812.netsh.html


表单的进化!

input添加的特性!

email

邮箱: <input type="email" name="user_email" >
  • 若是用submit提交会验证Email,检查是否缺少@,@后面是否为空….挺齐全的

url

首页: <input type="url" name="user_url" >
  • 同上,会检查内容格式,眼下仅仅支持绝对路径!!!!

number

页数: <input type="number" name="pagin" min="1" max="30" />
  • 有四个属性:

    • min : 最小值 , 小于会报错提醒
    • max : 最大值, 大于会报错提醒
    • step : 默觉得1, 能够看需求设置
    • value : 设置默认值,这个跟传统的一样

range

范围:<input type="range" name="range" min="5" max="25" />
  • 这个和上面那个非常相似,连属性值都一致了..就是表现形式不同,,显示为滚动栏
  • 值得一提的是,宽高度的不一致决定了滚动栏的方向是水平还是垂直;h>w.垂直!!

Date pickers

 <input type="[attribute]" name="user_week" />

[attribute]换成以下的属性就能看到各种效果了,,就是兼容性不怎么样,chrome下正常;

等到各大浏览器都支持良好了,就能代替JS日期选择器了…. 一条代码搞定一个日期选择;

  • date - 选取日、月、年
  • month - 选取月、年
  • week - 选取周和年
  • time - 选取时间(小时和分钟)
  • datetime - 选取时间、日、月、年(UTC 时间)
  • datetime-local - 选取时间、日、月、年(本地时间)

search

<input type="search" name="user_search" > 
  • 跟text相比,多了一个可关闭的X;另一些样式上的差别;其它基本一致

tel

联系方式: <input type="tel" name="user_tel" > 
  • 和text大同小异,支持不论什么字符输入

color

最喜欢的颜色: <input type="color" name="color" > 
  • 这个属性兼容性不是非常好,可是能够支持的浏览器体验非常好,就是一个color picker!!!

required

邮箱: <input type="email" name="user_email" required="required">
  • 防止域为空时提交表单,返回值是boolean, 设置了必须通过验证才干提交

placeholder

邮箱: <input type="email" name="user_email" required="required" placeholder="请输入您的邮箱!!">
  • 这个属性见怪不怪了,,有点相似占位符,显示一行浅灰色的字体,可是又是能够编辑的,也能够通过JS获取当输入为空的时候,用placeholder的值替换

pattern

电话号码: <input type="text" name="phone"
pattern="[1-9]{11}" title="联系人号码" />
  • 眼下非常少看到, 可是正则却非经常见,,待慢慢普及吧

novalidate

<form action="#" method="post" novalidate="true">
邮箱: <input type="email" name="user_email" required="required" placeholder="请输入您的邮箱!!" novalidate="true">
<input type="submit" />
</form>
  • H5特性之中的一个,验证表单值;
  • novalidate的作用就是取消验证,可作用于表单和input元素;
  • 默认不设置则为验证!

multiple

<form action="#" method="post" novalidate="true">
邮箱: <input type="email" name="user_email" required="required" placeholder="请输入您的邮箱!!" novalidate="true" multiple="multiple">
<input type="submit" />
</form>
  • 支持上传(file)和邮箱控件(email)输入多个值,值之间用逗号隔开(半角)

autofocus

    <input autofocus="autofocus" type="text">
  • 自己主动获取焦点

autocomplete

    <input autofocus="autofocus" type="text" autocomplete="no">
  • h5下该属性添加了开关功能(on/off),来决定是否自己主动完毕

表单新元素

datalist

搜索引擎: <input type="url" list="url_list" name="link" />
<datalist id="url_list">
<option label="Bing" value="http://www.bing.com" />
<option label="Baidu" value="http://www.baidu.com" />
<option label="Microsoft" value="http://www.microsoft.com" />
</datalist>
  • 如需把 datalist 绑定到输入域,请用输入域的 list 属性引用 datalist 的 id
  • 下拉默认值设置在option的value中

keygen

<form action="#" method="post">
username: <input type="text" name="usr_name" >
加密方式: <keygen name="security" >
<input type="submit" >
</form>
  • 非常多浏览器对这属性支持还不大完好,,,,
  • 加密方式两种,原理还是通过公钥和密钥的方式(相似SSH)

progress

<progress value="5" max="70">
</progress>
  • 进度条制作利器!!,用来推断file这些的载入挺不错的….
  • 必须设置max值才干显示相应的进度条,,不支持百分比!!!

meter

<div>您的额度:<meter value="50001" min="0" max="10000" low="1000" high="9000" optimum="6000">尽情耍!!</meter> </div>
  • 用的不多,,眼下;也是进度条效果
  • min/max是最小值和最大值;
  • value是当前值
  • low和high是低于和高于最优值(optimum)

总结

表单来了一次大跃进,可是吧,,眼下还是没法顺心的用,,一些浏览器没跟上,另一些用户使用老版本号浏览器;

所以这些新特性的使用,,哪怕再人性化,也仅仅能慢慢来;过渡总须要时间的~~~

HTML5基础知识汇总_(2)自己定义属性及表单新特性的更多相关文章

  1. HTML5基础知识汇总(一)

    一.HTML的开发工具和使用的浏览器 开发工具:记事本等文本编辑器,Atom.VisualStudioCode( VSCode).Brackets.Sublime text和Hbuider. 浏览器: ...

  2. HTML5 十大新特性(二)——表单新特性

    H5的表单新特性可以分为两大类. 一.10个input的type值 1.email:邮件输入域,在表单提交时提供简单的邮箱格式验证,并弹出一个提示窗口. 2.url:地址输入域,在表单提交时提供简单的 ...

  3. html5表单新特性

    type=range 值区域范围 默认值(0-100) type=data  选择日期 type=color value='初始值' 颜色选择器控件 type=search 搜索框效果 type=im ...

  4. jquery基础知识汇总

    jquery基础知识汇总 一.简介 定义 jQuery创始人是美国John Resig,是优秀的Javascript框架: jQuery是一个轻量级.快速简洁的javaScript库.源码戳这 jQu ...

  5. 沉淀,再出发:Java基础知识汇总

    沉淀,再出发:Java基础知识汇总 一.前言 不管走得多远,基础知识是最重要的,这些知识就是建造一座座高楼大厦的基石和钢筋水泥.对于Java这门包含了编程方方面面的语言,有着太多的基础知识了,从最初的 ...

  6. HTML基础知识汇总

    前言 一直想总结一下,苦于没有时间,正好看到了一个总结了不错的博客,我就在他的基础上进行一下测试并总结,原博地址:http://www.cnblogs.com/wanghzh/p/5805587.ht ...

  7. HTML5 学习总结(二)——HTML5新增属性与表单元素

    一.HTML5新增属性 1.1.contextmenu contextmenu的作用是指定右键菜单. <!DOCTYPE html> <html> <head> & ...

  8. HTML5 学习笔记(二)——HTML5新增属性与表单元素

    目录 一.HTML5新增属性 1.1.contextmenu 1.2.contentEditable 1.3.hidden 1.4.draggable 1.5.data-* 1.6.placehold ...

  9. 完善:HTML5表单新特征简介与举例——张鑫旭

    一.前言一撇 其实关于HTML5的表单特征早在去年“你必须知道的28个HTML5特征.窍门和技术”一文中就有所介绍(在第十一项),不过,有些遗憾的是,此部分的介绍是以视频形式展示的,其实,是视频还好啦 ...

随机推荐

  1. C/C++ 基础知识

    C/C++ 基础知识 C 语言优秀学习网站 [C Programming Language] C 语言的注释 单行注释 /* comment goes here */ // comment goes ...

  2. 【ASP.NET】必须知道的ASP.NET核心处理

    该找工作了,回头复习一下基础知识,增加一下理论知识的理解,下面我们看一下今天要说的. ASP.NET应用程序对象 一.请求的处理参数:上下文对象HttpContext 当一个请求到达ASP.NET服务 ...

  3. 其实参与QtCreator开发也很容易

    http://bbs.csdn.net/topics/370241186 10个月前发过一个组建Qt团队,共同研究.学习.完善QtCreator的帖子,不过在为QtCreator提交完一个补丁后,就没 ...

  4. apache几个常见配置文件的作用

    进行虚拟主机配置 NameVirtuaHost *:80 表示基于名称的虚拟主机  *:80表示监听本机所有IP的80端口上提供HTTP服务,*可以设置为具体IP<VirtualHost *:8 ...

  5. CodeForces 738D Sea Battle

    抽屉原理. 先统计最多有$sum$个船可以放,假设打了$sum-a$枪都没打中$a$个船中的任意一个,那么再打$1$枪必中. #pragma comment(linker, "/STACK: ...

  6. 洛谷——P2239 螺旋矩阵

    P2239 螺旋矩阵 题目描述 一个n行n列的螺旋矩阵可由如下方法生成: 从矩阵的左上角(第1行第1列)出发,初始时向右移动:如果前方是未曾经过的格子,则继续前进,否则右转:重复上述操作直至经过矩阵中 ...

  7. noip2012开车旅行 题解

    题目大意: 给出n个排成一行的城市,每个城市有一个不同的海拔.定义两个城市间的距离等于他们的高度差的绝对值,且绝对值相等的时候海拔低的距离近.有两个人轮流开车,从左往右走.A每次都选最近的,B每次都选 ...

  8. C++中的读入输出优化及清新脱俗的宏命令

    C和C++有了#define,从此它就变了模样 宏命令就是#define,#if,#error之类的 本文主要介绍宏命令和相关的骚操作 读入输出优化 inline int read() { int a ...

  9. Java编程思想学习(四)----第四章:控制执行流程

    在Java中,涉及的关键字包括if-else.while.do-while.for.return.break 以及选择语句switch.然而,Java并不支持goto语句(该语句引起许多反对意见,但它 ...

  10. Eclipse、svn插件、subclipse的安装

    1.下载subclipse的安装包       URL:http://subclipse.tigris.org/servlets/ProjectDocumentList?folderID=2240   ...