整理HTML5中表单的常用属性及新属性


Posted in HTML / CSS onFebruary 19, 2016

HTML5 新的表单属性
HTML5 的 <form> 和 <input>标签添加了几个新属性.
<form>新属性:
autocomplete
novalidate
<input>新属性:
autocomplete
autofocus
form
formaction
formenctype
formmethod
formnovalidate
formtarget
height and width
list
min and max
multiple
pattern (regexp)
placeholder
required
step

<form> / <input> autocomplete 属性
autocomplete 属性规定 form 或 input 域应该拥有自动完成功能。
当用户在自动完成域中开始输入时,浏览器应该在该域中显示填写的选项。
提示: autocomplete 属性有可能在 form元素中是开启的,而在input元素中是关闭的。
注意: autocomplete 适用于 <form> 标签,以及以下类型的 <input> 标签:text, search, url, telephone, email, password, datepickers, range 以及 color。
实例
HTML form 中开启 autocomplete (一个 input 字段关闭 autocomplete ):

XML/HTML Code复制内容到剪贴板
  1. <form action="demo-form.php" autocomplete="on">  
  2.   First name:<input type="text" name="fname"><br>  
  3.   Last name: <input type="text" name="lname"><br>  
  4.   E-mail: <input type="email" name="email" autocomplete="off"><br>  
  5.   <input type="submit">  
  6. </form>  

<form> novalidate 属性
novalidate 属性的一个boolean 属性.
novalidate 属性规定在提交表单时不应该验证 form 或 input 域。
实例
无需验证提交的表单数据

XML/HTML Code复制内容到剪贴板
  1. <form action="demo-form.php" novalidate>  
  2.   E-mail: <input type="email" name="user_email">  
  3.   <input type="submit">  
  4. </form>  

<input> autofocus 属性
autofocus 属性是一个 boolean 属性.
autofocus 属性规定在页面加载时,域自动地获得焦点。
实例
让 "First name" input 输入域在页面载入时自动聚焦:

XML/HTML Code复制内容到剪贴板
  1. First name:<input type="text" name="fname" autofocus>  

<input> form 属性
form 属性规定输入域所属的一个或多个表单。
提示:如需引用一个以上的表单,请使用空格分隔的列表。
实例
位于form表单外的input 字段引用了 HTML form (该 input 表单仍然属于form表单的一部分):

<input> formaction 属性
The formaction 属性用于描述表单提交的URL地址.
The formaction 属性会覆盖<form> 元素中的action属性.
注意: The formaction 属性用于 type="submit" 和 type="image".
实例
以下HTMLform表单包含了两个不同地址的提交按钮:

XML/HTML Code复制内容到剪贴板
  1. <form action="demo-form.php">  
  2.   First name: <input type="text" name="fname"><br>  
  3.   Last name: <input type="text" name="lname"><br>  
  4.   <input type="submit" value="Submit"><br>  
  5.   <input type="submit" formaction="demo-admin.php"  
  6.   value="Submit as admin">  
  7. </form>  

<input> formenctype 属性
formenctype 属性描述了表单提交到服务器的数据编码 (只对form表单中 method="post" 表单)
formenctype 属性覆盖 form 元素的 enctype 属性。
主要: 该属性与 type="submit" 和 type="image" 配合使用。
实例
第一个提交按钮已默认编码发送表单数据,第二个提交按钮以 "multipart/form-data" 编码格式发送表单数据:

XML/HTML Code复制内容到剪贴板
  1. <form action="demo-post_enctype.php" method="post">  
  2.   First name: <input type="text" name="fname"><br>  
  3.   <input type="submit" value="Submit">  
  4.   <input type="submit" formenctype="multipart/form-data"  
  5.   value="Submit as Multipart/form-data">  
  6. </form>  

<input> formmethod 属性
formmethod 属性定义了表单提交的方式。
formmethod 属性覆盖了 <form> 元素的的method 属性。
注意: 该属性可以与 type="submit" 和 type="image" 配合使用。
实例
重新定义表单提交方式实例:

XML/HTML Code复制内容到剪贴板
  1. <form action="demo-form.php" method="get">  
  2.   First name: <input type="text" name="fname"><br>  
  3.   Last name: <input type="text" name="lname"><br>  
  4.   <input type="submit" value="Submit">  
  5.   <input type="submit" formmethod="post" formaction="demo-post.php"  
  6.   value="Submit using POST">  
  7. </form>  

<input> formnovalidate 属性
novalidate 属性是一个 boolean 属性.
novalidate属性描述了 <input> 元素在表单提交时无需被验证。
formnovalidate 属性会覆盖 <form> 元素的novalidate属性.
注意: formnovalidate 属性与type="submit一起使用
实例
两个提交按钮的表单(使用与不适用验证 ):

XML/HTML Code复制内容到剪贴板
  1. <form action="demo-form.php">  
  2.   E-mail: <input type="email" name="userid"><br>  
  3.   <input type="submit" value="Submit"><br>  
  4.   <input type="submit" formnovalidate value="Submit without validation">  
  5. </form>  

<input> formtarget 属性
formtarget 属性指定一个名称或一个关键字来指明表单提交数据接收后的展示。
The formtarget 属性覆盖 <form>元素的target属性.
注意: formtarget 属性与type="submit" 和 type="image"配合使用.
实例
两个提交按钮的表单, 在不同窗口中显示:

XML/HTML Code复制内容到剪贴板
  1. <form action="demo-form.php">  
  2.   First name: <input type="text" name="fname"><br>  
  3.   Last name: <input type="text" name="lname"><br>  
  4.   <input type="submit" value="Submit as normal">  
  5.   <input type="submit" formtarget="_blank"  
  6.   value="Submit to a new window">  
  7. </form>  

<input> height 和 width 属性
height 和 width 属性规定用于 image 类型的 <input> 标签的图像高度和宽度。
注意: height 和 width 属性只适用于 image 类型的<input> 标签。
提示:图像通常会同时指定高度和宽度属性。如果图像设置高度和宽度,图像所需的空间 在加载页时会被保留。如果没有这些属性, 浏览器不知道图像的大小,并不能预留 适当的空间。图片在加载过程中会使页面布局效果改变 (尽管图片已加载)。
实例
定义了一个图像提交按钮, 使用了 height 和 width 属性:

XML/HTML Code复制内容到剪贴板
  1. <input type="image" src="img_submit.gif" alt="Submit" width="48" height="48">  

<input> list 属性
list 属性规定输入域的 datalist。datalist 是输入域的选项列表。
OperaSafariChromeFirefoxInternet Explorer
实例
在 <datalist>中预定义 <input> 值:

XML/HTML Code复制内容到剪贴板
  1. <input list="browsers">  
  2.   
  3. <datalist id="browsers">  
  4.   <option value="Internet Explorer">  
  5.   <option value="Firefox">  
  6.   <option value="Chrome">  
  7.   <option value="Opera">  
  8.   <option value="Safari">  
  9. </datalist>  

<input> min 和 max 属性
min、max 和 step 属性用于为包含数字或日期的 input 类型规定限定(约束)。
注意: min、max 和 step 属性适用于以下类型的 <input> 标签:date pickers、number 以及 range。
实例

XML/HTML Code复制内容到剪贴板
  1. <input> 元素最小值与最大值设置:   
  2. Enter a date before 1980-01-01:   
  3. <input type="date" name="bday" max="1979-12-31">  
  4.   
  5. Enter a date after 2000-01-01:   
  6. <input type="date" name="bday" min="2000-01-02">  
  7.   
  8. Quantity (between 1 and 5):   
  9. <input type="number" name="quantity" min="1" max="5">  

<input> multiple 属性
multiple 属性是一个 boolean 属性.
multiple 属性规定<input> 元素中可选择多个值。
注意: multiple 属性适用于以下类型的 <input> 标签:email 和 file。: email, and file.
实例
上传多个文件:

XML/HTML Code复制内容到剪贴板
  1. Select images: <input type="file" name="img" multiple>  

<input> pattern 属性
pattern 属性描述了一个正则表达式用于验证 <input> 元素的值。
注意:pattern 属性适用于以下类型的 <input> 标签: text, search, url, tel, email, 和 password.
提示: 是用来全局 title 属性描述了模式.
实例
下面的例子显示了一个只能包含三个字母的文本域(不含数字及特殊字符):

XML/HTML Code复制内容到剪贴板
  1. Country code: <input type="text" name="country_code" pattern="[A-Za-z]{3}" title="Three letter country code">  

<input> placeholder 属性
placeholder 属性提供一种提示(hint),描述输入域所期待的值。
简短的提示在用户输入值前会显示在输入域上。
注意: placeholder 属性适用于以下类型的 <input> 标签:text, search, url, telephone, email 以及 password。
实例
input 字段提示文本t:

XML/HTML Code复制内容到剪贴板
  1. <input type="text" name="fname" placeholder="First name">  

<input> required 属性
required 属性是一个 boolean 属性.
required 属性规定必须在提交之前填写输入域(不能为空)。
注意:required 属性适用于以下类型的 <input> 标签:text, search, url, telephone, email, password, date pickers, number, checkbox, radio 以及 file。
实例
不能为空的input字段:

XML/HTML Code复制内容到剪贴板
  1. Username: <input type="text" name="usrname" required>  

<input> step 属性
step 属性为输入域规定合法的数字间隔。
如果 step="3",则合法的数是 -3,0,3,6 等
提示: step 属性可以与 max 和 min 属性创建一个区域值.
注意: step 属性与以下type类型一起使用: number, range, date, datetime, datetime-local, month, time 和 week.
实例
规定input step步长为3:

XML/HTML Code复制内容到剪贴板
  1. <input type="number" name="points" step="3">  

<output> 元素
HTML5 还引入了一个新元素 <output>,用来表示不同类型的输出结果,比如输出由脚本所写。

还可以用 for 属性指定输出元素和文档中影响计算的其他元素之间的关系(比如,作为输入源或者参数)。for 属性的值是一个由空格分隔的其他元素的 IDs 列表。

placeholder 属性
HTML5 引入了一个叫做 palceholder 的新属性。这个属性在 <input> 和 <textarea> 元素上为用户提供了在这个字段可以输入什么的提示。占位符字符不能包含回车符或者换行符。
下面是 placeholder 属性的简单语法:

XML/HTML Code复制内容到剪贴板
  1. <input type="text" name="search" placeholder="search the web"/>  

这个属性只有最新版的 Mozilla,Safari 以及 Chrome 浏览器支持。

required 属性
现在,我们不需要使用 JavaScript 处理诸如空文本框永远不能被提交的这类客户端验证了,因为 HTML5 引入了一个叫做 required 的新属性,可以按照如下方式使用,它会保证输入框有值:

XML/HTML Code复制内容到剪贴板
  1. <input type="text" name="search" required/>  

这个属性只有最新版的 Mozilla,Safari 以及 Chrome 浏览器支持。

HTML / CSS 相关文章推荐
纯CSS3编写的的精美动画进度条(无flash/无图像/无脚本/附源码)
Jan 07 HTML / CSS
css3打造一款漂亮的卡哇伊按钮
Mar 20 HTML / CSS
CSS3媒体查询Media Queries基础学习教程
Feb 29 HTML / CSS
CSS3制作酷炫的条纹背景
Nov 09 HTML / CSS
基于HTML5 Canvas 实现商场监控实例详解
Nov 20 HTML / CSS
html5音频_动力节点Java学院整理
Aug 22 HTML / CSS
canvas学习笔记之绘制简单路径
Jan 28 HTML / CSS
html5之Canvas路径绘图、坐标变换应用实例
Dec 26 HTML / CSS
html5 svg 中元素点击事件添加方法
Jan 16 HTML / CSS
HTML5拖拽的简单实例
May 30 HTML / CSS
详解移动端h5页面根据屏幕适配的四种方案
Apr 15 HTML / CSS
CSS的class与id常用的命名规则
May 18 HTML / CSS
浅谈基于HTML5的在线视频播放方案
Feb 18 #HTML / CSS
全面解析HTML5中的标准属性与自定义属性
Feb 18 #HTML / CSS
简单整理HTML5的基本特性和语法
Feb 18 #HTML / CSS
HTML5实现预览本地图片
Feb 17 #HTML / CSS
HTML5新特性之用SVG绘制微信logo
Feb 03 #HTML / CSS
HTML5未来发展趋势
Feb 01 #HTML / CSS
详解HTML5中的Communication API基本使用方法
Jan 29 #HTML / CSS
You might like
php array_map array_multisort 高效处理多维数组排序
2009/06/11 PHP
PHP IN_ARRAY 函数使用注意事项
2010/07/24 PHP
php网站被挂木马后的修复方法总结
2014/11/06 PHP
PHP技术开发微信公众平台
2015/07/22 PHP
WordPress开发中用于标题显示的相关函数使用解析
2016/01/07 PHP
基于jquery的时间段实现代码
2012/08/02 Javascript
一个JavaScript函数把URL参数解析成Json对象
2014/09/24 Javascript
node.js中的http.response.end方法使用说明
2014/12/14 Javascript
JavaScript中的Repaint和Reflow用法详解
2015/07/27 Javascript
一不小心就做错的JS闭包面试题
2015/11/25 Javascript
JS用斜率判断鼠标进入DIV四个方向的方法
2016/11/07 Javascript
JS实现问卷星自动填问卷脚本并在两秒自动提交功能
2020/06/17 Javascript
微信小程序使用for循环动态渲染页面操作示例
2018/12/25 Javascript
angular4自定义组件非input元素实现ngModel双向数据绑定的方法
2018/12/28 Javascript
[01:13:46]iG vs Winstrike 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
深入解析Python中的上下文管理器
2016/06/28 Python
Django使用httpresponse返回用户头像实例代码
2018/01/26 Python
实时获取Python的print输出流方法
2019/01/07 Python
python反编译学习之字节码详解
2019/05/19 Python
PyQt4实时显示文本内容GUI的示例
2019/06/14 Python
python 应用之Pycharm 新建模板默认添加编码格式-作者-时间等信息【推荐】
2019/06/17 Python
python递归法实现简易连连看小游戏
2020/03/25 Python
详解如何在pyqt中通过OpenCV实现对窗口的透视变换
2020/09/20 Python
乌克兰网上服装店:Bolf.ua
2018/10/30 全球购物
Moss Bros官网:英国排名第一的西装店
2020/02/26 全球购物
成都思必达公司C#程序员招聘面试题
2013/06/26 面试题
幼儿运动会邀请函
2014/01/17 职场文书
毕业实习评语
2014/02/10 职场文书
大学军训感言300字
2014/03/09 职场文书
股权转让协议书
2014/04/12 职场文书
学生会主席演讲稿
2014/04/25 职场文书
学校班班通实施方案
2014/06/11 职场文书
新课程改革心得体会
2016/01/22 职场文书
2019职场单身人才调研报告:互联网行业单身比例最高
2019/08/07 职场文书
Python集合的基础操作
2021/11/01 Python
POST提交数据常见的四种方式
2022/01/18 HTML / CSS