HTML中的表单

1. form表单有什么作用

form表单用于把用户输入的数据提交给后台服务器
name表示提交的表单名称,action表示数据提交的地址,methods表示数据提交的方式,有get和post,默认是get

常用的input标签类型(type)
  • 单行文本输入框

  • 密码输入框
    读书

  • 单选框

  • file

  • 提交输入

  • 重置输入

  • button

  • hidden

input里面的name

name规定了input元素的名称
name属性用于对提交到服务器后的表单数据进行标识,或者在客户端通过JS引用表单数据
注释:只有设置了 name 属性的表单元素才能在提交表单时传递它们的值。

2. GET和 POST方式的区别

HTTP定义了与服务器交互的不同方法,最基本的方法有4种,分别是GET,POST,PUT,DELETE。URL全称是资源描述符,我们可以这样认为:一个URL地址,它用于描述一个网络上的数据,而HTTP中的GET,POST,PUT,DELETE就对应着对这个数据的查,改,增,删4个操作。到这里,大家应该有个大概的了解了,GET一般用于获取/查询数据,而POST一般用于更新数据。

原理不同
  • GET用于信息获取,而且应该是安全的和幂等的
  1. 这里的安全是说GET操作不会修改数据,只会查询数据,不会改变服务器资源状态。
  2. 幂等意味着对同一URL的多个请求应该返回同样的结果。这里我再解释一下幂等这个概念:

幂等(idempotent、idempotence)是一个数学或计算机学概念,常见于抽象代数中。
  幂等有以下几种定义:
  对于单目运算,如果一个运算对于在范围内的所有的一个数多次进行该运算所得的结果和进行一次该运算所得的结果是一样的,那么我们就称该运算是幂等的。比如绝对值运算就是一个例子,在实数集中,有abs(a)=abs(abs(a))。
  对于双目运算,则要求当参与运算的两个值是等值的情况下,如果满足运算结果与参与运算的两个值相等,则称该运算幂等,如求两个数的最大值的函数,有在在实数集中幂等,即max(x,x) = x。

  • 运用在这里,幂等就是不管你操作多少次,结果都一样,比如你 get index,不过你 get 多少次,都是获取 index。但是 post 就不幂等,因为 post第一次是新建一个post,第二次是新建第二个。
  • POST请求可能改变服务器上的资源
表象不同
  1. GET 请求的数据会拼接到action属性所指的URL地址之后,比如jirengu.com?username=tail&password=123456
    POST则是把提交的数据打包到HTTP包的包体中,也就是HTML HEADER内一起传送到action属性所指的URL地址。
  2. GET与POST 提交的数据大小理论上没有限制,但是由于GET是通过URL提交数据,那么GET提交数据的大小就由URL决定了,理论上URL长度也没有限制,URL长度取决于浏览器对其的限制。POST数据起限制作用的是服务器的处理能力。

参考资料:浅谈HTTP中Get与Post的区别

其他
  • GET后退按钮/刷新无害,POST数据会被重新提交(浏览器应该告知用- 户数据会被重新提交)。
  • GET书签可收藏,POST为书签不可收藏。
  • GET能被缓存,POST不能缓存 。
  • GET历史参数保留在浏览器历史中。POST参数不会保存在浏览器历史中。
  • GET编码类型application/x-www-form-url,POST编码类型application/x-www-form-urlencoded 或 multipart/form-data。为二进制数据使用多重编码。
  • GET只允许 ASCII 字符。POST没有限制。也允许二进制数据

3. radio 如何 分组?

radio通过name值来分组,name相同的为一组。

4. placeholder 属性有什么作用?

placeholder 是HTML5的新属性
placeholder 属性提供可描述输入字段预期值的提示信息。
该提示会在输入字段为空时显示,并会在字段获得焦点时消失。
注释:placeholder 属性适用于以下的 类型:text, password、 search, url, telephone,以及 email

5. type=hidden隐藏域有什么作用?

隐藏域具体写法:

hidden隐藏域无外乎下面六点作用:
  • 隐藏域在页面中对于用户是不可见的,在表单中插入隐藏域的目的在于收集或发送信息,以利于被处理表单的程序所使用。浏览者单击发送按钮发送表单的时候,隐藏域的信息也被一起发送到服务器。
  • 有些时候我们要给用户一信息,让他在提交表单时提交上来以确定用户身份,如sessionkey,等等.当然这些东西也能用cookie实现,但使用隐藏域就简单的多了.而且不会有浏览器不支持,用户禁用cookie的烦恼。
  • 有些时候一个form里有多个提交按钮,怎样使程序能够分清楚到底用户是按那一个按钮提交上来的呢?我们就可以写一个隐藏域,然后在每一个按钮处加上onclick="document.form.command.value="xx""然后我们接到数据后先检查command的值就会知道用户是按的那个按钮提交上来的。
  • 有时候一个网页中有多个form,我们知道多个form是不能同时提交的,但有时这些form确实相互作用,我们就可以在form中添加隐藏域来使它们联系起来。
  • javascript不支持全局变量,但有时我们必须用全局变量,我们就可以把值先存在隐藏域里,它的值就不会丢失了。
  • 还有个例子,比如按一个按钮弹出四个小窗口,当点击其中的一个小窗口时其他三个自动关闭.可是IE不支持小窗口相互调用,所以只有在父窗口写个隐藏域,当小窗口看到那个隐藏域的值是close时就自己关掉

6. HTML表单的用法

你可能感兴趣的:(HTML中的表单)