HTML5 Web Form 新增属性和表单验证
<form>标签的基本属性
method属性:指定浏览器向服务器传送数据的方式,可选;
action属性:设置服务器接受和处理表单数据的URL;
enctype属性:制定表单数据在发送到服务器之前进行编码的编码方式;
accept属性:指定能够通过文件上传进行提交的文件类型;
accept-charset属性:指定服务器处理表单数据所接收的字符集;
target属性:制定浏览器在提交表单后生成的页面在哪个框加载或在哪个窗口显示;
id属性:用来识别网页中的form标签;
name属性:用来识别网页中的form标签;
autocomplete属性:新增属性,是否启用自动完成设置,on/off,默认on
novalidate属性:新增属性,是否启用表单验证功能,novalidate="novalidate".
表单结构的元素标签
label标签:设置输入性控件的说明信息;
input标签:定义表单的输入类型控件;
button标签:定义表单的按钮;
fieldset标签:fieldset和lenged标签用来将相应的表单控件分组;
lenged标签:fieldset和lenged标签用来将相应的表单控件分组;
select标签:创建下拉列表框;
<optgroup>标签:以选项租的形式定义下拉列表框;
textarea标签:用来定义一个文本区域;
datalist标签:datalist和option标签组合用来定义输入域的选项列表;
output标签:新增标签,定义不同类型的输出,特别是在用脚本的计算结果的显示中应用广泛;
keygen标签:定义表单的密钥对生成器字段。
保留的输入类型控件
text控件:文本的单行输入字段;
password控件:密码字段;
button控件:点击的按钮;
file控件:文件上传组件;
image控件:一个图像形式的提交按钮;
radio控件:单选按钮;
chekbox控件:复选框;
hidden控件:隐藏字段;
submit控件:提交按钮;
reset控件:重置按钮。
新增输入类型控件
email控件:邮件地址的输入域;
url控件:URL地址的输入域;
number控件:数字的输入域;
range控件:包含一定范围内数值的滑动条输入域;
search控件:搜索域,results属性指定显示搜索结果的条数;
color控件:颜色选择域;
date控件:日期选择域;
month控件:月份的输入域;
week控件:星期选择域;
time控件:时间选择域;
datetime控件:date和time控件的整合,日期和时间的输入域;
datetime-local控件:date和time控件的整合,时间和日期的输入域,默认显示本地时间;
telephone控件:电话号码输入域。
新增表单的标签属性
placeholder属性:定义一个占位符,提示用户该输入域期望输入的值;
required属性:定义一个必填项;
pattern属性:定义一个正则表达式对输入域进行验证;
mutiple属性:定义输入域可以选择多个值;
list属性:list和datalist标签组合,用来定义输入域的选项列表;
min属性:限定输入值得最小值;
max属性:限定输入值的最大值;
step属性:数值的过度间隔;
novalidate属性:是否启用验证功能;
autocomplete属性:是否启用自动完成设置;
autofocus属性:规定当页面加载时自动获得焦点,autofocus ="autofocus".
表单的验证机制(由接口validityState提供以下属性进行验证)
valid属性:有效,当填写的内容符合要求时触发;对应invalid;
valueMissing属性:返回一个必填字段是否有内容;
typeMismatch属性:用来返回用户输入的内容是否符合类型,主要面对Email,URL,number这三个输入类型的控件;true/false;
tooLong属性:用来返回用户输入的内容是否超过规定的长度;
stepMismatch属性:用来返回用户输入的内容是否超过规定的长度,是否符合step的过度间隔;
rangeUnderflow属性:用来返回用户输入的数字是否小于设置的最小值,关联min属性,相对的是rangeOverflow;
patternMisMatch属性:用来返回用户输入的内容是否满足规定的验证要求,关联pattern使用;
custonError属性:用于定义一些自定义的错误信息!属性mode:on/off/RemoteOnly,属性defaultRedirect重定向URL。
获取validityState接口:
<script>
var username;
var validityState;
function load(){
username = document.getElementById('username');
validityState = username.validity;
}
window.addEventListener("load",load,false);
</script>
<input type = "text" id="username"/>
用户自定义表单错误的函数和属性(customError用户自定义错误)
setCustomValidity()函数:用来设置错误信息;
willValidate属性:用来返回某输入类型控件是否将进行表单验证;
checkValidity函数:用来进行表单验证;所有的验证有效,返回true,触发valid事件,否则,返回false触发invalid事件;
validationMessage函数:用来显示相关的用户提示信息;
preventDefault函数:用来关闭浏览器的默认错误提示信息。
HTML5 Web Form 新增属性和表单验证的更多相关文章
- HTML5 学习总结(二)——HTML5新增属性与表单元素
一.HTML5新增属性 1.1.contextmenu contextmenu的作用是指定右键菜单. <!DOCTYPE html> <html> <head> & ...
- HTML5 学习笔记(二)——HTML5新增属性与表单元素
目录 一.HTML5新增属性 1.1.contextmenu 1.2.contentEditable 1.3.hidden 1.4.draggable 1.5.data-* 1.6.placehold ...
- 关于Web项目里的给表单验证控件添加结束时间不得小于开始时间的验证方法,日期转换和前台显示格式之间,还有JSON取日期数据格式转换成标准日期格式的问题
项目里有些不同页面间的日期显示格式是不同的, 第一个问题: 比如我用日期控件WdatePicker.js导包后只需在input标签里加上onClick="WdatePicker()" ...
- HTML5学习总结——HTML5新增属性与表单元素
一HTML5新增属性 1.1contcxtmcnu contextmenu的作用是指定右键菜单. <!DOCTYPE html> <html> <head> < ...
- vue 新增时清除表单验证注意事项
// 清除表单校验的提示 if (this.$refs['XXX']) { // 延时执行 this.$nextTick(function () { this.$refs['XXX'].clearVa ...
- JS组件系列——Form表单验证神器: BootstrapValidator
前言:做Web开发的我们,表单验证是再常见不过的需求了.友好的错误提示能增加用户体验.博主搜索bootstrap表单验证,搜到的结果大部分都是文中的主题:bootstrapvalidator.今天就来 ...
- 黄聪: Bootstrap之Form表单验证神器: BootstrapValidator(转)
前言:做Web开发的我们,表单验证是再常见不过的需求了.友好的错误提示能增加用户体验.博主搜索bootstrap表单验证,搜到的结果大部分都是文中的主题:bootstrapvalidator.今天就来 ...
- asp.net 登陆验证 Form表单验证的3种方式 FormsAuthentication.SetAuthCookie;FormsAuthentication.RedirectFromLoginPage;FormsAuthenticationTicket
我们在登陆成功后,使用下面的3种方法,都是同一个目的:创建身份验证票并将其附加到 Cookie, 当我们用Forms认证方式的时候,可以使用HttpContext.Current.User.Ident ...
- Form表单验证神器: BootstrapValidator
前言:做Web开发的我们,表单验证是再常见不过的需求了.友好的错误提示能增加用户体验.博主搜索bootstrap表单验证,搜到的结果大部分都是文中的主题:bootstrapvalidator.今天就来 ...
随机推荐
- 【BZOJ 1051】【HAOI 2006】受欢迎的牛
tarjan缩点模板 #include<cstdio> #include<cstring> #include<algorithm> using namespace ...
- Java并发和多线程(一)基础知识
1.java线程状态 Java中的线程可以处于下列状态之一: NEW: 至今尚未启动的线程处于这种状态. RUNNABLE: 正在 Java 虚拟机中执行的线程处于这种状态. BLOCKED: 受阻塞 ...
- Hash Length Extension Attacks
catalogue . Hash函数的内部原理 . 漏洞原理 1. Hash函数的内部原理 0x1: 分组.Padding 哈希函数以区块为单位操作数据.比如说,MD5, SHA1, SHA256的区 ...
- C# 获取当前,相对,绝对路径
一.C#获取当前路径的方法: 1. System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName -获取模块的完整路径. 2. ...
- AngularJs form.FormController、ngModel.NgModelController
form.FormController FormController跟踪所有他所控制的和嵌套表单以及他们的状态,就像有效/无效或者脏值/原始. 每个表单指令创建一个FormController实例. ...
- 强连通分量的Tarjan算法
资料参考 Tarjan算法寻找有向图的强连通分量 基于强联通的tarjan算法详解 有向图强连通分量的Tarjan算法 处理SCC(强连通分量问题)的Tarjan算法 强连通分量的三种算法分析 Tar ...
- django makemigrations的一个特性
Migrations will run the same way on the same dataset and produce consistent results, meaning that wh ...
- python获取知乎日报另存为txt文件
前言 拿来练手的,比较简单(且有bug),欢迎交流~ 功能介绍 抓取当日的知乎日报的内容,并将每篇博文另存为一个txt文件,集中放在一个文件夹下,文件夹名字为当日时间. 使用的库 re,Beautif ...
- Linux运维工程师入门的10大实用工具
说到工具,在行外可以说是技能,在行内我们一般称为工具,就是运维必须要掌握的工具. 我就大概列出这几方面,这样入门就基本没问题了. 工具如下: 1.Linux系统基础 这个不用说了,是基础中的基础,连这 ...
- 和redis谈一场恋爱(第一天邂逅)
前几天玩了下Memcache,发现挺好用.知道redis是Memcache的妹妹.我本着大公无私和博大的胸怀,看着redis孤零零的躺在角落里,委实觉得可怜.心里总有个声音在说,你既然已经爱上了Mem ...