HTML表单

1.**
元素 **……

元素包含构成表单的所有元素,还会告诉浏览器当你提交表单时要把表单数据发送哪里,以及浏览器要用什么方法发送数据。

属性 含义
action 规定当提交表单时向何处发送表单数据。
method 确定表单数据如何发送到服务器
target target 属性规定在何处打开 action URL
enctype 规定在发送到服务器之前应该如何对表单数据进行编码。
accept-charset 规定服务器用哪种字符集处理表单数据。
  • enctype属性的属性值:
属性值 含义
application/x-www-form-urlencoded 在发送前编码所有字符(默认)
multipart/form-data 不对字符编码。在使用包含文件上传控件的表单时,必须使用该值。
text/plain 空格转换为 "+" 加号,但不对特殊字符编码。

2.元素

  • 文本输入text
  • 密码输入passward
  • 单选radio
    一组给定选项关联的单选钮必须有相同的名字name。但在不同的表单中,name可以相同。value为提交表单的值
  • 复选框checkbox
    相关的复选框也共用一个名字。
  • 数字输入number
  • email输入 tel输入 url输入
  • 上传文件file,注意accept属性

    表示只接受png格式的图片。
  • 隐藏域hidden

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

3.按钮

  • 具有提交功能
  • 只是一个按钮,不能提交表单
  • 清除表单数据
属性值 功能
submit 该按钮是提交按钮(除了 Internet Explorer,该值是其他浏览器的默认值)。
button 该按钮是可点击的按钮(Internet Explorer 的默认值)。
reset 该按钮是重置按钮(清除表单数据)。

4.文本区