HTML5学习笔记(四):H5中表单新增元素及改良
方便布局
表单内容可以放在表单标签之外,这样做的好处是方便设计时不用考虑一定要将表单元素放在指定的form标签之下,只要指定元素适用于哪个表单即可,如下:
<form id="test" action="test.php" method="get">
<input form="test" type="text" name="name"/>
</form>
<input form="test" type="submit" value="确定"/>
可指定提交按钮的目标及方法
在HTML5之前,一个表单只能填写一个action及一个method,在HTML5中每个提交按钮都可以指定自己的action及method,如下:
<!-- HTML5以前的表单写法 -->
<form action="test.php" method="get">
<input type="text" name="name"/>
<input type="submit" value="确定"/>
</form>
<!-- HTML5的表单写法 -->
<form>
<input type="text" name="name"/>
<input type="submit" value="确定POST" formaction="test1.php" formmethod="post"/>
<input type="submit" value="确定GET" formaction="test2.php" formmethod="get"/>
</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可以用来将文字和指定的单选框、复选框或者任意的控件进行绑定,我们可以点击文字就如同点击到对应的控件一般:
<!-- 直接包含写法 -->
<form>
<label>
<input type="checkbox" value="value">
请选择这个复选框
</label>
</form>
<!-- 通过for进行指定 -->
<form>
<input type="checkbox" value="value" id="cb">
<label for="cb">请选择这个复选框</label>
</form>
标签的control属性
标签的control属性指定了标签包含或指向的控制对象,可以通过获取该属性来拿到对应的控件,如果标签包含了多个控件,则该属性表示第一个控件。
<script>
function setDefault() {
var label = document.getElementById("label");
var input = label.control;
input.value = "123456";
}
</script>
<form>
<label id="label">
<input type="text">
</label>
<input type="button" value="点击设定默认值" onclick="setDefault()">
</form>
placeholder
输入框指定了该属性后,会作为一个提示文字在输入框没有输入时显示。
<input type="text" placeholder="请输入手机号">
带提示及可输入的文本框
在HTML5中可以通过datdlist来定义一个带有下拉提示的输入框,如下:
<form>
<input type="text" list="dl">
<datalist id="dl">
<option value="HTML5">HTML5学习</option>
<option value="Android">Android学习</option>
<option value="IOS">IOS学习</option>
</datalist>
</form>
除了可以输入预订的信息外,还可以输入任意的信息。
autocomplete
在使用了autocomplete标记的输入框进行过一次提交之后,下一次再次输入会出现上次输入的文本,可以实现快速补齐的功能。
<form action="test.php" method="get" autocomplete="on">
<input type="text">
<input type="submit">
</form>
pattern属性
pattern属性可以设定为一个正则表达式,为输入框设定了pattern属性之后,在提交时会对输入的文本进行检查,当发现不能匹配时会进行提示:
<form action="test.php" method="get">
<input type="text" pattern="[A-Z]{3}" name="part">
<input type="submit">
</form>
上面的示例,只有在输入3个大写字母之后才能进行正确提交。
input元素的新增种类
在HTML5中,对input元素的种类进行了增加,用url类型来作为说明,使用了url类型,则在提交时,会验证填写的内容是否为url地址,实际上是方便了开发者,免去了常用的验证代码的编写。
新增种类如下:http://www.w3school.com.cn/html5/html_5_form_input_types.asp
有个不好的地方是,每个浏览器对新类型的外观设计都是不一样的,所以为了追求统一性,在大网站上,还是需要使用风格统一的类型,比如日期选择器等,个人感觉在编写快速小应用时可以使用到这些新增的类型。
HTML5学习笔记(四):H5中表单新增元素及改良的更多相关文章
- Flutter学习笔记(22)--单个子元素的布局Widget(Container、Padding、Center、Align、FittedBox、Offstage、LimitedBox、OverflowBox、SizedBox)
如需转载,请注明出处:Flutter学习笔记(22)--单个子元素的布局Widget(Container.Padding.Center.Align.FittedBox.Offstage.Limited ...
- HTML5学习笔记<五>: HTML表单和PHP环境搭建
HTML表单 1. 表单用于不同类型的用户输入 2. 常用的表单标签: 标签 说明 <form> 表单 <input> 输入域 <textarea> 文本域 < ...
- HTML5学习笔记<四>: 列表, 块和布局
HTML列表 列表标签 标签 描述 <ol> 定义有序列表. <ul> 定义无序列表. <li> 定义列表项. <dl> 定义定义列表. <dt& ...
- HTML5学习笔记四 HTML文本格式化
HTML 格式化标签 HTML 使用标签<b> 与<i> 对输出的文本进行格式, 如:粗体 or 斜体 这些HTML标签被称为格式化标签 通常标签 <strong> ...
- HTML5学习笔记四:html5结构
一.大纲:大纲即文档中各内容区块的结构编排 1. 显示编排内容区块:使用section等元素创建文档结构,每个内容区块使用标题(h1~h6,hgroup); 2. 隐式编排内容区块:根据页面所书写的各 ...
- [html5] 学习笔记-表单新增的元素与属性(续)
本节主要讲解表单新增元素的controls属性.placeholder属性.List属性.Autocomplete属性.Pattern属性.SelectionDirection属性.Indetermi ...
- python3.4学习笔记(四) 3.x和2.x的区别,持续更新
python3.4学习笔记(四) 3.x和2.x的区别 在2.x中:print html,3.x中必须改成:print(html) import urllib2ImportError: No modu ...
- Html5学习笔记1 元素 标签 属性
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- HTML5学习笔记之表格标签
HTML5学习笔记之表格标签 其他HTML5相关文章 HTML5学习笔记之HTML5基本介绍 HTML5学习笔记之基础标签 HTML5学习笔记之表格标签 HTML5学习笔记之表单标签 HTML5学习笔 ...
随机推荐
- appium日志示例解读
http://www.colabug.com/thread-1048952-1-1.html
- TabLayout自定义tab,实现多样导航栏
代码地址如下:http://www.demodashi.com/demo/14660.html 前言 之前有讲过TabLayout的一些知识, TabLayout实现顶部导航(一) TabLayout ...
- 【JS】移动端 好用的分享插件 soshm.js
参考链接:https://www.cnblogs.com/milo-wjh/p/6796082.html 对于qq内置浏览器分享功能处理:https://www.cnblogs.com/xuzheng ...
- 使用maven命令安装jar包到本地仓库
第三方jar包在开发工具中引入后编译没问题, 启动调试包括打包时会提示找不到jar包的错误.需要上传到maven仓库中,并在pom文件内引入. maven命令: 安装指定文件到本地仓库命令:mvn i ...
- 【LeetCode】230. Kth Smallest Element in a BST (2 solutions)
Kth Smallest Element in a BST Given a binary search tree, write a function kthSmallest to find the k ...
- 【LeetCode】201. Bitwise AND of Numbers Range
Bitwise AND of Numbers Range Given a range [m, n] where 0 <= m <= n <= 2147483647, return ...
- 命令行参数解析函数getopt和getopt_long函数【转】
原文地址:http://blog.csdn.net/cashey1991/article/details/7942809 getopt和getopt_long函数 平时在写程序时常常需要对命令行参 ...
- O'Reilly总裁提姆-奥莱理:什么是Web 2.0
O'Reilly总裁提姆-奥莱理:什么是Web 2.0 译者序:Web 2.0这一概念,由O'Reilly媒体公司总裁兼CEO提姆·奥莱理提出.他是美国IT业界公认的传奇式人物,是“开放源码”概念的缔 ...
- VS2010编译Boost 1.56
(1)首先下载源代码:http://softlayer-dal.dl.sourceforge.net/project/boost/boost/1.56.0/boost_1_56_0.zip 解压到某个 ...
- 【java】详解java中的注解(Annotation)
目录结构: contents structure [+] 什么是注解 为什么要使用注解 基本语法 4种基本元注解 重复注解 使用注解 运行时处理的注解 编译时处理的注解 1.什么是注解 用一个词就可以 ...