博客列表 >HTML 表单基础

HTML 表单基础

尹辉
尹辉原创
2023年03月15日 16:15:48419浏览

HTML 表单基础

一、表单域

HTML <form> 元素表示文档中的一个区域,此区域包含交互控件,用于收集用户的信息和数据,向 Web 服务器提交信息。
常见的表单域如用户登录界面:

表单域由<form>标签创建,格式如下:

  1. <form name="表单名称" method="发送数据的方法(get/post)" action="后端处理页面">
  2. 表单元素(标签、输入框、按钮等)
  3. </form>

其中:

  1. name 属性:表单名称,后端处理页面根据这个名称确定是哪个表单提交的数据
  2. method 属性:发送表单数据的方法,常用的有 get、post:

    • get 方法:用于数据较少,安全性要求低的情况,传输的数据会显示在浏览器的地址栏
    • post 方法:用于数据较多,安全性要求高的情况
  3. action 属性:指定处理表单数据的后端页面(向何处发送表单数据)

二、表单元素

1,<input> 表单输入元素

HTML<input>元素用于为基于 Web 的表单创建交互式控件,以便接受来自用户的数据。<input>元素是目前是 HTML 中最强大、最复杂的元素之一,因为它有大量的输入类型和属性组合。

  • 基本格式
    1. <input type="类型" name="名称" 其他可选属性 >
    其中:
    • type 属性:指定<input>的类型,如文本框、密码框、单选框、提交按钮等,默认为 “text”。
    • name 属性:用于后端处理页面识别是哪个表单元素提交的数据。
    • 其他可选属性:如 disabled(不可用)、required(必填/选)、readonly(只读)等
  • 常用类型
    • text:单行文本框
      代码:
      1. <form>
      2. <input type="text" name="userName" value="" placeholder="请输入内容">
      3. </form>
      页面显示效果:
    • password:密码框
      代码:
      1. <form>
      2. <input type="password" name="userpassword" value="123456">
      3. </form>
      页面显示效果:

      注释:password 字段中的字符会被做掩码处理(显示为星号或实心圆)。
    • submit:提交按钮
      代码:
      1. <form>
      2. <input type="submit" name="submit1" value="提交">
      3. </form>
      页面显示效果:
    • reset:重置按钮,数据不提交,重置所有组件为初始值
      代码:
      1. <form>
      2. <input type="reset" value="重置">
      3. </form>
      页面显示效果:
    • radio:单选框
      代码:
      1. <form>
      2. 男孩<input type="radio" name="gender" value="boy" checked>
      3. 女孩<input type="radio" name="gender" value="girl">
      4. </form>
      页面显示效果:

      注意:同一组单选框的 name 属性值要相同
    • checkbox:复选框
      代码:
      1. <form>
      2. 爱好:
      3. <input type="checkbox" name="music" value="1" checked>音乐
      4. <input type="checkbox" name="sport" value="2">体育
      5. <input type="checkbox" name="reading" value="3">阅读
      6. </form>
      页面显示效果:
    • 其他类型参考 mdn web docs:https://developer.mozilla.org/zh-CN/docs/Web/HTML/Element/input

2,<label>标签

HTML <label>元素(标签)表示用户界面中某个元素的说明。通常与<input>输入元素一起使用,为<input>定义标注。
当点击标签文字是,关联的<input>元素会被激活获取焦点,就像直接点击<input>元素一样。这扩大了元素的可点击区域,让包括使用触屏设备在内的用户更容易激活这个元素。
将一个 <label> 和一个 <input> 元素匹配在一起方法有两种:

  • <input> 一个 id 属性。而 <label> 需要一个 for 属性,其值和 <input>id 一样:
    代码:
    1. <form>
    2. <label for="inputText1">用户名:</label>
    3. <input type="text" name="userName" id="inputText1" value="" placeholder="请输入用户名">
    4. </form>
    页面显示效果:
  • <input> 直接放在 <label> 里,此时则不需要 forid 属性,因为关联已隐含存在:
    代码:
    1. <form>
    2. <label>
    3. 用户名:
    4. <input type="text" name="userName" value="" placeholder="请输入用户名">
    5. </label>
    6. </form>
    页面显示效果:

3,<select>下拉列表

HTML <select>元素表示一个提供选项菜单的控件,可创建单选或多选菜单,<select>元素中的<option>标签用于定义列表中的可用选项。

  • 默认为单选:
    代码:
    1. <form>
    2. <label>
    3. 城市:
    4. <select name="city" id="city">
    5. <option value="shanghai">上海</option>
    6. <option value="beijing">北京</option>
    7. <option value="suzhou" selected>苏州</option>
    8. </select>
    9. </label>
    10. </form>
    页面显示效果:
  • 添加 multiple 属性后为多选(按住ctrl键选取多个选项)。
    代码:
    1. <form>
    2. <label>
    3. 城市:
    4. <select name="city" id="city" multiple>
    5. <option value="shanghai">上海</option>
    6. <option value="beijing">北京</option>
    7. <option value="suzhou" selected>苏州</option>
    8. </select>
    9. </label>
    10. </form>
    页面显示效果:

4,<button>按钮

HTML<button>元素表示一个可点击的按钮,可以用在表单或文档其他需要使用简单标准按钮的地方。示例:
代码:

  1. <form>
  2. <button type="submit">提交</button>
  3. </form>

页面显示效果:

<button> 元素比 <input> 元素更容易使用样式。可以在<button> 元素内添加 HTML 内容(像 <em><strong> 甚至 <img>),而 <input> 只支持文本内容。
注意:在<form>表单域中使用<button>时,需要始终指定 type 值( button / submit ),因为在不同浏览器中,<button>的 type 默认值不一样。

5,<textarea>文本域

HTML<textarea>元素表示一个多行纯文本编辑控件,当希望用户输入一段相当长的、不限格式的文本,例如评论或反馈表单中的一段意见时,这很有用。
代码:

  1. <form>
  2. <textarea name="textarea" rows="10" cols="50">Write something here</textarea>
  3. </form>

页面显示效果:

可以通过 cols 和 rows 属性来规定<textarea>的尺寸,不过更好的办法是使用 CSS 的 height 和 width 属性。

6,<fieldset>分组

HTML <fieldset> 元素用于对表单中的控制元素进行分组。用内置的<legend>元素作为 <fieldset> 的标题。
代码:

  1. <form action="#">
  2. <fieldset>
  3. <legend>分组标题</legend>
  4. <input type="radio" id="radio">
  5. <label for="radio">单选框</label>
  6. </fieldset>
  7. </form>

页面显示效果:

三、实例

以下是应用上述知识点做的一个用户注册界面实例。
代码:

  1. <h3>新用户注册</h3>
  2. <form name="userRegister" method="post" action="#">
  3. <fieldset>
  4. <legend>基本信息</legend>
  5. <p>
  6. <label for="userName">用户名:</label>
  7. <input id="userName" type="text" required>
  8. </p>
  9. <p>
  10. <label for="userPassword">密码:</label>
  11. <input id="userPassword" type="password" placeholder="6~8位字母和数字" required>
  12. </p>
  13. </fieldset>
  14. <fieldset>
  15. <legend>详细信息</legend>
  16. <p>
  17. <label for="email">邮箱:</label>
  18. <input id="email" type="email">
  19. </p>
  20. <p>
  21. 性别:
  22. <label for="male">男:</label>
  23. <input name="sex" id="male" value="male" type="radio" checked>
  24. <label for="female">女:</label>
  25. <input name="sex" id="female" value="female" type="radio">
  26. </p>
  27. <p>
  28. <label for="education">学历:</label>
  29. <select name="edu" id="education">
  30. <option value="1">初中</option>
  31. <option value="2">高中</option>
  32. <option value="3" selected>本科</option>
  33. <option value="4">硕士</option>
  34. <option value="5">博士</option>
  35. </select>
  36. </p>
  37. <p>
  38. 爱好:
  39. <input type="checkbox" name="program" value="1" checked>编程
  40. <input type="checkbox" name="sport" value="2">体育
  41. <input type="checkbox" name="reading" value="3">阅读
  42. <input type="checkbox" name="trip" value="4" checked>旅游
  43. <input type="checkbox" name="other" value="5">其他
  44. </p>
  45. 自我介绍:
  46. <p>
  47. <textarea name="textarea" rows="10" cols="50">
  48. </textarea>
  49. </p>
  50. </fieldset>
  51. <button type="submit">提交</button>
  52. <button type="reset">重置</button>
  53. </form>

页面显示效果:

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议