HTML 表单秘籍

表单是什么?

从某种意义上来说,“表单”就相当于一份问卷,这份问卷有一些空白的地方需要你来填写答案。

例如

知乎登录
Google的搜索框

表单如何工作?

用户填写表单,然后单击一个按钮将所填信息提交到服务器,之后每个表单中的控件的名字和用户输入或选择的值将会被一同发送给服务器。

用户填写表单,然后单击提交
表单中所有控件的名字和对应值被服务器接收

form表单

1. form表单有什么作用?

用来为网站搜集来自访问者的信息,不论是要向网站加一个简单的搜索框,还是要创建更复杂的保险申请单,都可以通过form表单中的控件来完成。

2. <form>表单结构

action特性

每个<from>元素都应该设置action特性,其特性值是服务器上一个页面的URL,这个页面用来在用户提交表单时接收表单中的信息。

method特性

表单的提交可以采用以下两种方法

1. get

使用get方法时,表单中的值被附加在由action特性所指的URL末尾

用户名和密码都显示在URL的末尾
2. post

使用post方法时,表单中的值被放在HTTP头信息中进行发送。

URL没有显示被提交的数据
被提交的数据被放到了HTTP头信息中

ps:
1. get是用来从服务器上获得数据,而post是用来向服务器上传数据
2. get将表单中数据按照variable=value的形式,添加到action所指向的URL后面,并且两者用“?”连接,而各个变量之间用“&”连接;post是将表单中的数据放在form的数据体中,按照变量和值相对应的方式,传到action所指向URL
3. Get方式并不安全,因为在传输过程中,数据被放在了请求的URL中,而如今现有的很多服务器、代理服务器或者用户代理都会将请求URL记录到日志文件中,放在某个地方保存,这样就会被第三方看到。另外,用户也可以直接在浏览器上看到被提交的数据,一些系统内部消息将会一同显示在用户面前。Post的所有操作用户都是看不到的。
4. get传输的数据量小,因为URL的长度是有限制的;而post可以传输大量数据,所以在上传文件时,只能用post
5. get限制form表单的数据值必须为ASCII字符;而post支持整个ISO10646字符集。

get&post取舍

那么我们什么时候用get什么时候用post呢?

情况 方法
短表单例如搜索框 get
只从web服务器上检索数据的情况 get
用户上传文件 post
非常长 post
包含敏感信息(例如密码) post
向数据库中添加或删除数据 post

ps:
1. 如果<form>中没有使用method特性表单中的数据将用get方式发送
2. 所有的表单控件都应位于<from>元素中。
3. 每个<from>元素都应该设置action特性,通常还要设置method特性和id特性。

 <form action="/getInfo" method="get">
 </form>

表单控件多种多样的input

<input>

  • input元素用来创建不同的表单控件,其type特性的值决定了它将要创建哪种控件
  • 当用户向表单中输入信息时,服务器需要知道每条数据被输入到了哪个表单控件。

例如,在一个登录表单中,服务器需要知道哪条数据是作为用户名输入的,哪条数据提供的是密码。因此,每个表单控件都需要一个name特性,这个特性的值对表单控件进行标识并输入的信息一同传送到服务器。

单行文本框

当type特性的值为text时,<input>y元素会创建一个单行文本框

 <input id="username" type="text" name="username" value="ruo">
单行文本框效果

密码框

当type特性的值为password时,<input>y元素会创建一个用起来和单行文本框类似的文本框,唯一不同之处在于其中的字符被隐藏起来为的是让那些在用户背后旁观的人看不到想密码这样的敏感数据。
ps:在任何文本输入控件上,你还可以使用一个名为placeholder的特性,在用户单击文本输入区域之前,文本框内显示的文本就是placeholder的特性的值。

 <input id="password" type="password" name="password" placeholder="输入密码">
密码框效果

文本域(多行文本框)

  • <textarea>元素用来创建多行文本框。与其他input元素不同,<textarea>元素并非空元素,因此它包含起始标签和结束标签
  • 页面加载时,在起始标签<textarea>和结束标签</textarea>之间出现的所有文本将显示在相应的文本框中。
 <textarea name="article">
         多行文本,注意和 type=text的区别
 </textarea>
文本域效果

单选按钮

单选按钮只让用户从一系列选项中选择其中一个
ps:

  • 当一个问题以单选按钮的形式给用户提供一系列答案时,用来回答这个问题的所有单选按钮的name特性值都应该相同
  • value特性为选项指定了被选中时要发送到服务器的值,同一组中的每个按钮的值应该各不相同(这样服务器才知道用户选择了哪个选项)
  • checked特性用来指定当页面加载时哪个选项会被选中
      <input type="radio" name="sex" value="男"> 男
      <input type="radio" name="sex" value="女"> 女  
单选按钮效果

复选框

复选框允许用户在回答一个问题时选择一个或多个选项
ps:

  • 当一个问题以复选框的形式给用户提供一系列答案时,用来回答这个问题的所有复选框的name特性值都应该相同
  • value特性指定复选框在被选中时需要发送到服务器的值
  • checked特性用来指定当页面加载时哪个选项会被选中
      <input type="checkbox" name="hobby" value="read"> 读书
      <input type="checkbox" name="hobby" value="music"> 听歌
      <input type="checkbox" name="hobby" value="study"> 学习
复选框效果

下拉列表框

下拉列表框让用户在一个下拉列表中选择其中一个选项
ps:

  • name特性指定这个表单控件的名称,此名称与用户选择的选项值一并发送到服务器
  • <select>元素用来创建下拉列表框,它包含两个或者两个以上的<option>元素
  • <option>元素用于指定用户选择的选项,在起始标签<option>和结束标签</option>之间的文字将显示在下拉列表中
  • <option>元素使用value特性来指定选项的值,如果该选项被选中,那么这个值将于控件的名称一并发送到服务器
  • selected特性可以用来指定当页面加载时被选中的选项。如果未使用selected特性,那么在页面加载时,下拉列表框中显示的将是第一个选项。如果用户没有选择任何选项那么列表中的第一个项目将作为这个控件的值被传送到服务器
  • 下拉列表框的功能与单选按钮的功能类似,在抉择这两种方式的时候要考虑以下两点
  • size特性的值是你希望一次显示的选项数量
  • multiple特性来允许用户从这一列表中选择多个选项

  1. 如果用户需要一眼看到所有的选项,那么当然单选按钮更合适一些
  2. 如果是一个非常长的选项列表(如国家列表),那么下拉列表框则更适合一些
<select name="city">
        <option value="beijing">北京</option>
        <option value="shanghai" selected>上海</option>
        <option value="hangzhou">杭州</option>
      </select>
下拉列表框效果

文件上传域

如果你希望让用户上传文件(例如图像、视频、MP3或者PDF等),就需要使用文件域
ps:

  • type="file"这个类型的input会创建一个后面附有选择文件(Browse)按钮的类似文本框的控件,当用户单击按钮时会弹出一个新窗口,来让用户们在他们的计算机中选择文件来上传到网站
  • 如果允许用户上传文件,那么<form>元素上的method特性值设置为post(HTTP get方式是不能发送文件的)
<input type="file" name="myfile"">
文件上传域效果

提交按钮

提交按钮用来将表单发送给服务器
ps:

  • value特性用于控制在按钮上的文本
<input type="submit" value="提交" />
提交按钮效果

隐藏控件hidden

提交按钮用来将表单发送给服务器
ps:

  • 隐藏域在页面中对于用户是不可见的,在表单中插入隐藏域的目的在于收集或发送信息,以利于被处理表单的程序所使用。浏览者单击发送按钮发送表单的时候,隐藏域的信息也被一起发送到服务器。
  • 有些时候我们要给用户一信息,让他在提交表单时提交上来以确定用户身份,如sessionkey,等等.当然这些东西也能用cookie实现,但使用隐藏域就简单的多了.而且不会有浏览器不支持,用户禁用cookie的烦恼。
  • 有些时候一个form里有多个提交按钮,怎样使程序能够分清楚到底用户是按那一个按钮提交上来的呢?我们就可以写一个隐藏域,然后在每一个按钮处加上onclick="document.form.command.value="xx""然后我们接到数据后先检查command的值就会知道用户是按的那个按钮提交上来的。
<input type="hidden" name="csrf" value="12345623fafdffdd">
  • 这时,所提交的表单就会附加:csrf=12345623fafdffdd的内容。

placeholder 属性有什么作用?

在用户输入值之前,输入字段中将显示短提示,也就是placeholder的值。
ps:

  • 占位符属性适用于以下输入类型:文本,搜索,网址,电话,电子邮件和密码
<input id="password" type="password" name="password" placeholder="输入密码">
placeholder效果
本文章著作权归饥人谷_ghj和饥人谷所有,转载须说明来源
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,383评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,522评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,852评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,621评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,741评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,929评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,076评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,803评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,265评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,582评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,716评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,395评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,039评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,027评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,488评论 2 361
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,612评论 2 350

推荐阅读更多精彩内容

  • 表单基础知识 在HTML中,表单是由 元素来表示的,而在JS中,表单对应的则是HTMLFormElement类型。...
    oWSQo阅读 906评论 0 1
  • 内容抽屉菜单ListViewWebViewSwitchButton按钮点赞按钮进度条TabLayout图标下拉刷新...
    皇小弟阅读 46,733评论 22 665
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,066评论 4 62
  • 鞭炮 人流 呼喊 团聚 饭菜 欢笑 一幅和谐的场面 回家 车流 拥挤 工作 挣钱 无奈 这个可怜的世界
    青山白鹭阅读 197评论 0 0
  • 1.目标感,好不夸张的说,决定一个人的命运。陈纯军昨天让我今天早上九点半去接一个妹子,说给我介绍的,已经说好了,让...
    小l新阅读 150评论 1 0