方便布局
表单内容可以放在表单标签之外,这样做的好处是方便设计时不用考虑一定要将表单元素放在指定的form标签之下,只要指定元素适用于哪个表单即可,如下:
1 <form id="test" action="test.php" method="get">
2 <input form="test" type="text" name="name"/>
3 </form>
4 <input form="test" type="submit" value="确定"/>
可指定提交按钮的目标及方法
在HTML5之前,一个表单只能填写一个action及一个method,在HTML5中每个提交按钮都可以指定自己的action及method,如下:
1 <!-- HTML5以前的表单写法 -->
2 <form action="test.php" method="get">
3 <input type="text" name="name"/>
4 <input type="submit" value="确定"/>
5 </form>
6 <!-- HTML5的表单写法 -->
7 <form>
8 <input type="text" name="name"/>
9 <input type="submit" value="确定POST" formaction="test1.php" formmethod="post"/>
10 <input type="submit" value="确定GET" formaction="test2.php" formmethod="get"/>
11 </form>
enctype和formenctype
enctype属性规定在发送到服务器之前应该如何对表单数据进行编码。
- application/x-www-form-urlencoded:表单数据被编码为名称/值对。这是默认的编码方式(空格转换为 "+" 加号,特殊符号转换为 ASCII HEX 值)。
- multipart/form-data:不对字符编码。在使用包含文件上传控件的表单时,必须使用该值。
- text/plain:空格转换为 "+" 加号,但不对特殊字符编码。
同上,enctype也可以针对每个提交按钮进行指定,使用formenctype即可。
target和formtarget
类似于<a>标签的target属性,form标签的target属性控制提交数据之后,action指向的地址的打开方式,其可填写的值于<a>标签的值意义和写法完全一致,默认为_self。
同上,每个提交按钮也可以配置自己的target,使用formtarget即可。
autofocus
使用该属性,可以在页面打开时将焦点自动设定到设置了该属性的组件上。
<input type="text" name="name" autofocus/>
required
指示输入字段的值是必需的,如果不填值就提交会出现提示并且也不会有提交的动作发出。
<input type="text" name="name" required/>
label
在我们使用单选框或复选框时,一般这个后面都会跟上一段文字,但是我们点击这段文字时却是无效的,label可以用来将文字和指定的单选框、复选框或者任意的控件进行绑定,我们可以点击文字就如同点击到对应的控件一般:
1 <!-- 直接包含写法 -->
2 <form>
3 <label>
4 <input type="checkbox" value="value">
5 请选择这个复选框
6 </label>
7 </form>
8 <!-- 通过for进行指定 -->
9 <form>
10 <input type="checkbox" value="value" id="cb">
11 <label for="cb">请选择这个复选框</label>
12 </form>
标签的control属性
标签的control属性指定了标签包含或指向的控制对象,可以通过获取该属性来拿到对应的控件,如果标签包含了多个控件,则该属性表示第一个控件。
1 <script>
2 function setDefault() {
3 var label = document.getElementById("label");
4 var input = label.control;
5 input.value = "123456";
6 }
7 </script>
8 <form>
9 <label id="label">
10 <input type="text">
11 </label>
12 <input type="button" value="点击设定默认值" onclick="setDefault()">
13 </form>
placeholder
输入框指定了该属性后,会作为一个提示文字在输入框没有输入时显示。
<input type="text" placeholder="请输入手机号">
带提示及可输入的文本框
在HTML5中可以通过datdlist来定义一个带有下拉提示的输入框,如下:
1 <form>
2 <input type="text" list="dl">
3 <datalist id="dl">
4 <option value="HTML5">HTML5学习</option>
5 <option value="Android">Android学习</option>
6 <option value="IOS">IOS学习</option>
7 </datalist>
8 </form>
除了可以输入预订的信息外,还可以输入任意的信息。
autocomplete
在使用了autocomplete标记的输入框进行过一次提交之后,下一次再次输入会出现上次输入的文本,可以实现快速补齐的功能。
1 <form action="test.php" method="get" autocomplete="on">
2 <input type="text">
3 <input type="submit">
4 </form>
pattern属性
pattern属性可以设定为一个正则表达式,为输入框设定了pattern属性之后,在提交时会对输入的文本进行检查,当发现不能匹配时会进行提示:
1 <form action="test.php" method="get">
2 <input type="text" pattern="[A-Z]{3}" name="part">
3 <input type="submit">
4 </form>
上面的示例,只有在输入3个大写字母之后才能进行正确提交。
input元素的新增种类
在HTML5中,对input元素的种类进行了增加,用url类型来作为说明,使用了url类型,则在提交时,会验证填写的内容是否为url地址,实际上是方便了开发者,免去了常用的验证代码的编写。
有个不好的地方是,每个浏览器对新类型的外观设计都是不一样的,所以为了追求统一性,在大网站上,还是需要使用风格统一的类型,比如日期选择器等,个人感觉在编写快速小应用时可以使用到这些新增的类型。