form表单有什么作用?有哪些常用的input 标签,分别有什么作用?
表单在网页中主要负责数据采集功能,form标签,用于申明表单,定义采集数据的范围,也就是<form>和</form>里面包含的数据将被提交到服务器或者电子邮件里。
常用标签及作用
- 单行文本框:用于输入单行文本,如用户名、邮箱等
<input type="text" name="名称" placeholder="默认值" />
- 密码框:用于输入密码,输入的字符会显示成点
<input type="password" name="名称" />
- 多选框:可以选择一项或多项,name相同的项表示在同一组
<input id="data" value="data" type="checkbox" name="hobby"></input><label for="data">data</label>
<input id="travel" value="travel" type="checkbox" name="hobby"></input><label for="travel">旅游</label>
<input id="animals" value="animals" type="checkbox" name="hobby"></input><label for="animals">宠物</label>
- 单选框:仅可选择一项,name相同的项表示在同一组
<input value="male" id="sex-man" type="radio" name="sex" checked></input><label for="sex-man">男</label>
<input value="female" id="sex-woman" type="radio" name="sex"></input><label for="sex-woman">女</label>
- 下拉选单:以下拉的方式显示可选项
<select name="myCar">
<option name="benz" value="benz">奔驰</option>
<option name="BMW" value="BMW" selected>宝马</option>
<option name="Audi" value="Audi">奥迪</option>
</select>
- 多行文本:能输入较多行数的文本
<textarea name="名称" placeholder="默认值" rows="行数"></textarea>
- 按钮:button是普通按钮。submit表示提交,可将表单上的内容提交到服务器。reset表示重置,将输入框中的内容设置成默认值
<input type="button" name="名称" value="按钮" />
<input type="submit" name="名称">
<input type="reset" name="名称">
- 文件选择:用于选择上传的文件
<input type="file" name="名称" />
post 和 get 方式的区别
- 数据传送时:Get将表单中数据的按照variable=value的形式,添加到action所指向的URL后面,并且两者使用“?”连接,而各个变量之间使用“&”连接;Post是数据存放在http协议的消息体中以实体方式传输。
- 传送的数据量:受url长度的限制,get方式传输的数据量是有限的,而post方式是没有限制的。
- 安全性: get方式直接把数据显示在url中,浏览器有缓存,可记录用户信息,因此安全性低;而post方式没有这样的问题。
- 用户刷新时:post方式会弹出提示框,问用户是否重新提交,而get方式不会有提示。
在input里,name 有什么作用
- 作为可与服务器交互数据的HTML元素的服务器端的标示,在服务器端根据Name通过Request.Params取得元素提交的值,只有设置了 name 属性的表单元素才能在提交表单时传递它们的值。
- 对于单选框和复选框控件来说,name相同的表示在同一组。
radio 如何分组
name相同的radio在一组,同一组的radio只能选择一项
<input type="radio" name="a" value="man" id="a1" />
<input type="radio" name="a" value="woman" id="a2"/>
placeholder 属性有什么作用
显示的默认提示,该提示会在输入字段为空时显示,并会在字段获得焦点时消失,适用于以下的 <input> 类型:text, search, url, telephone, email 以及 password。
type=hidden隐藏域有什么作用? 举例说明
- 隐藏域用来收集或发送信息的不可见元素,对于网页的访问者来说,隐藏域是看不见的。当表单被提交时,隐藏域就会将信息用设置时定义的名称和值发送到服务器上。
举例
- 可以用来存储记录用户身份的信息,当表单提交时以确定用户身份。这种方式相较于cookie而言更简单,而且不会有浏览器不支持和用户禁用cookie的烦恼。
- 有些时候一个form里有多个提交按钮,怎样使程序能够分清楚到底用户是按那一个按钮提交上来的呢?我们就可以写一个隐藏域,然后在每一个按钮处加上onclick="document.form.command.value="xx""然后我们接到数据后先检查command的值就会知道用户是按的那个按钮提交上来的。
- 有时候一个网页中有多个form,我们知道多个form是不能同时提交的,但有时这些form确实相互作用,我们就可以在form中添加隐藏域来使它们联系起来。
- javascript不支持全局变量,但有时我们必须用全局变量,我们就可以把值先存在隐藏域里,它的值就不会丢失了。
网友评论