什么是表单

表单在网页中主要负责数据采集功能。HTML 中的 <form> 标签,就是用于采集用户输入的信息,并通过<form>标签的提交操作,把采集到的信息提交到服务器端进行处理。

表单组成部分

表单由三部分组成

  1. 表单标签
  2. 表单域
  3. 表单按钮

表单域:包含了文本框、密码框、隐藏域、多行文本框、复选框、单选框、下拉选择框和文件上传框等。

form 标签的属性

<form> 标签用来采集数据,而 <form> 标签的属性则是用来规定如何把采集到的数据发送到服务器

属性

描述

action

URL 地址

规定当提交表单时,向何处发送表单数据

method

get 或 post

规定以何种方式把表单数据提交到 action URL

enctype

application/x-www-form-urlencoded

multipart/form-data

text/plain

规定在发送表单数据之前如何对其进行编码

target

_blank

_self

_parent

_top

framename

规定在何处打开 action URL

action:用来规定提交表单时,向何处发送表单数据。属性的值应该是后端提供的一个 URL 地址,这个 URL 地址专门负责接收表单提交过来的数据。但是当 <form> 表单在未指定 action 的属性值的情况下,action 的默认值为当前页面的 URL 地址。需要注意的是,当提交表单后,页面会立即跳转到 action 属性指定的 URL 地址。

target:用来规定在何处打开 action URL。它的可选值有 5 个,默认情况下,target 的值是 _self,表示在相同的框架中打开 action URL。

描述

_blank

在新窗口打开

_self

默认。在相同的框架中打开

_parent

在父框架中打开 -- 很少用

_top

在整个窗口打开 -- 很少用

framename

在指定的框架中打开 -- 很少用

method:用来规定以何种方式把表单数据提交到 action URL。它的值有两个,分别是 get 和 post。默认情况下,method 的值为 get,表示通过 URL 地址的形式,把表单数据提交到 action URL。get 方式适合用来提交少量的、简单的数据。post 方式适合用来提交大量复杂或包含文件上传的数据。

enctype:用来规定在发送表单数据之前如何对数据进行编码。它的值有三个,默认情况下,enctype 的值为 application/x-www-form-urlencoded,表示在发送前编码所有的字符。初次之外还有 multipart/form-data,它表示不对字符进行编码,在使用包含文件上传控件的表单时,必须使用该值;text/plain,表示空格转换为 "+" 加号,但不对特殊字符编码(很少用)。需要注意的是,在涉及到文件上传时,必须将 enctype 的值设置为 multipart/form-data;如果表单的提交不涉及到文件上传操作,则直接将 enctype 的值设置为 application/x-www-form-urlencoded 即可。

表单的同步提交以及缺点

表单的同步提交

通过点击 submit 按钮,触发表单提交的操作,从而使页面跳转到 action URl 的行为,叫做表单的同步提交。

缺点

  1. <form> 表单同步提交后,整个页面会发生跳转,跳转到 action URL 所指向的地址,用户体验很差。
  2. <form> 表单同步提交后,页面之前的状态和数据会丢失

解决

表单值负责采集数据,Ajax 负责把数据提交到服务器。