HTML表单

1. 创建表单

每个表单都以 form 开始标签开始,以 form 结束标签结束。两个标签之间是组成表单的说明标签、控件和按钮。每个控件都有一个 name 属性,用于在提交表单时对数据进行识别。form 开始标签可以有一些属性,其中最重要的就是 action 和 method。将 action 属性的值设置为访问者提交表单时服务器上对数据进行处理脚本的 URL。method 属性值要么是 get,要么是 post。大多情况下是 post。

  <form method="post" action="xxx.php">
  </form>

对表单元素进行组织:如果表单上有很多信息需要填写,可以使用 fieldset 元素(类似一个边框)将相关的元素组合在一起,使表单更容易理解。还可以使用 legend 元素为每个fieldset 提供一个标题,用于描述每个组的目的(有时还可以使用 h1~h6)。

<form action="">
<fieldset>
    <h1>...</h1>
</fieldset>

<fieldset>
    <h2>...</h2>
    <div>
        <fieldset><div class="">
            <legend>小标题</legend>
        </div></fieldset>
    </div>
</fieldset>

</form>

2.创建文本

 

文本框可以包含一行无格式的文本,它可以是访问者想输入的任何内容,通常用于姓名、地址等信息。每个文本框都是通过带有 type = "text" 的 input 标签表现出来的。除了 type 之外还有些其他可用的属性,其中最重要的就是 name。服务器端的脚本使用你指定的 name 获取访问者在脚本文本框中输入的值或预设的值(即 value 属性值)。

创建文本框步骤:

  • 1)输入用于让访问者识别文本框的标签:标签描述的是表单字段用途的文本,label元素有一个特殊属性:for。如果 for 的值与一个表单字段的 id 值相同,该 label 就与该字段显示的关联起来。

    <label for = "idlabel"> Last Name:</label>

 

  • 2)输入 <input type = "text",表示文本框,然后在输入 name = "dataname"用于让服务器脚本识别输入数据的文本

 

 

  • 3)设置 id = "idlabel",这里跟 1)步中的 for 属性值一样,使得具有显示文本框的 label 元素关联。(id 和 for 属性设置相同并不是必须的)。

 

 

  • 4)如果需要,输入 value="default",这里 default 是这个字段最初默认显示的数据。

 

 

  • 5)如果需要,输入 placeholde = "hinttext",这里的 hinttext 是这个字段中最初显示的数据,用于指导用户输入,当 input 元素获得焦点时,这些文本就会消失。用户输入内容。

 

 

  • 6)如果需要,输入 required = "required",表示仅在这个字段有值的情况下才能提交表单。

 

 

  • 7)如果需要,输入 autofocus 或 autofocus = "autofocus"。如果这是第一个拥有此属性的表单控件,input 元素在页面加载时默认会获得焦点。

 

 

  • 8)如果需要,输入通过输入 size="n"定义文本框的大小,这里 n 是文本框宽度,以字符为单位。

 

  • 9)如果需要,输入 maxlength="n",这里 n 是该文本框允许输入的最大字符数。

 提交表单   Last Name:

   <fieldset>
  <legend> 提交表单 </legend>
  <label for = "idlabel"> Last Name: </label>
  <input type = "text" id = "idlabel" name = "dlabel" class = "field-large"
   required autofocus />
   </fieldset>

让 for、id 和 name 属性值都一样是一种并非必须但是很常见的做法(单选框和复选框例外,对它们来说有一组 input 会使用同一个 name,而 id 对每个 input 来说都是唯一的)。

3.创建密码框

创建密码框的步骤和创建文本大致相同,唯一区别的地方在于 type 的值变为 type = "password"。密码框中输入的文本会使用圆点或星号隐藏。

 <fieldset>
  <legend> 提交表单 </legend>
 <label for = "idlabel"> Last Name: </label>
 <input type = "password" id = "idlabel" name = "dlabel" class = "field-large"
   required autofocus />
 </fieldset>

创建电子邮件框、搜索框、电话框和URL框

同创建文本的步骤相同,唯一区别的地方在于type属性值的变化。

电子邮件:type = "email";
搜索框:type = "search";
电话框:type = "tel";
URL框:type = "url";

4. 创建单选按钮

 

对 input 元素设置 type = "radio" 即可创建单选按钮。然后输入 name 和 value 值,如果需要输入 checked 或者 checked = "checked" 让该单选按钮在页面打开时默认处于激活状态。一组单选按钮只能有一个按钮添加该属性。

Male

     <input type = "radio" name = "gender" value = "Male" />
     <label for = "idgender"> Male </label>

5.创建复选框

在一组单选按钮中,只允许选择一个答案;但在一组复选框按钮中,访问者可以选择任意数量的答案。

  • 1)输入 input type = "checkbox",

  • 2)输入 name = "boxset,id = "idlabel",value = "data"

  • 3)输入 checked 或 checked = "checked",让该复选框在页面打开时默认处于选中状态。

  • 4)输入 label for = "idlabel"

It's okay to ...emali me with ...messages from other ...

 <input type = "checkbox" id = "email- ok" 
 name = "email - signup" value = "user- emails" />
<label for = "email- ok" > It's okay to ...</label>
  
   <input type = "checkbox" id = "email-ok- to" 
   name = "email - signup" value = "user- emails- to" />
 <label for = "email- ok-to" > emali me with ...</label>
 
  <input type = "checkbox" id = "email- ok- three" 
  name = "email- signup" value = "user- emails- three" />
 <label for = "email- ok- three" > messages from other ...</label>

6.创建文本区域:

 

如果希望填写问题或评论的空间,可以使用文本区域。

  • 1)输入 textarea

  • 2)输入 id = "idlabel",输入 name = "dataname"

  • 3)如果需要,输入 maxlength = "n"

  • 4)输入 cols = "n" 这里n是文本的宽度,输入 rows = "n"这里 n 是文本区域的高度。

    <textarea name = "bio" id = "bio" cols = "40" rows = "10"> </textarea>

    7.创建选择框

    选择框用于向访问者提供一组选项,从而允许从中选择。通常呈现为下拉菜单样式,如果允许用户选择多个选项,选择框就会呈现为一个带滚动条的项目框。

 

  • 1)输入 select

 

 

  • 2)输入 id = "idlabel",输入 name = "dataname"

 

 

  • 3)如果需要,设置 size="n",这里 n 代表选择框的高度

 

 

  • 4)如果需要,输入 multiple 或者 multiple = "multiple",从而允许访问者选择一个以上的菜单选项(选择时需要按住 Control 键或 Command 键)。

 

 

  • 5)输入 option

 

 

  • 6)输入 value = "optiondata" 选项选中后要发送给服务器的数据

 

  • 7)如果需要输入 selected 或者 selected = "selected",指定该选项默认被选中。输入希望出现在菜单中的名称。
    <select name = "state" id = "state">
    <option value = "Al"> Alabama </option>
    <option value = "Ak"> Alsska </option>
    <option value = "GS"> GSLYYDS </option>
    </select>

    8.让访问者上传文件

    有时需要让网站的用户向服务器上传文件(如照片。简历)。

 

  • 1)输入form method = "post" enctype = "multipart / form-data" enctype 属性可以确保文件采用正确的格式上传

 

 

  • 2)接下来,输入 action = upload.url。要上传的文件路径

 

 

  • 3)为文件上传区域输入标签

 

 

  • 4)输入 input type = "life"创建一个文件上传框和一个按钮,

 

 

  • 5)输入id = "idlabel",输入name = "dataname",如果需要,设置size = "n"

 

  • 6)如果需要,输入 multiple 或者 multiple = "multiple"
    <form method = "POST" action = "xxx.php" enctype = "multipart / form- data">
    <fieldset>
    <legend> 请上传 </legend>
    
     <label for = "picture"> Picture: </label>
    <input type = "file" id = "picture" name = "picture" />
    </fieldset>

    9.创建隐藏字段

    隐藏字段可以用于存储表单中的数据,但它不会显示给访问者。可以认为它们是不可见的文本框,通常用于储存先前的表单收集信息,以便将这些信息同当前的数据一起交给脚本处理。input type = "hidden",输入name = "dataname",value = "data"。

    10.创建提交按钮

    输入的信息如果不发送到服务器,就没什么用,应该总是为表单创建提交按钮,让访问者可以将信息交给你。提交按钮可以是文本。图像或二者结合。

    输入 input type = "submit.如果需要输入 value = "submit mesage" 将要出现在按钮上的文本。

    <input type = "submit" value = "GSL">

    创建带图像的提交按钮

  • 1)创建PNG、GIF、或JPEG图像。
  • 2)输入 input type = "image"
  • 3)输入 src = "image.url",这里 image.url 是图像在服务器上的位置。
  • 4)输入 alt = "text",当图像无法显示时需要出现的文本
    <input type="image" src="xxx.png" width="188" height="95" alt="Create Profile" />

    创建结合文本和图像的提交按钮:使用 button 元素可以创建包含其他HTML元素的按钮(存在兼容性问题)输入 button type = "submit"

    <button type = "submit" class = "btn">
    <img src = "xxx.png" width = "21" height = "21" alt ="">
    Create Profile 
    </button>

    11.禁用表单元素

    在某些情况下,你可能不想让访问者使用表单中某些部分,例如在所有必填信息完成之前禁用提交按钮。

    方法:在表单元素的开始标签后 输入 disabled 或者 disabled =" disabled"。

    12.根据状态为表单设置样式

    可能需要根据表单状态是否必须包含某个属性设置不同的样式。

  • :focus 获得焦点字段
  • :checked 选中的单选按钮或复选按钮、
  • :  disabled 具有 disabled 属性的字段、
  • :  enable 与  disabled 相反、
  • :required 具有 required 属性的字段
  • :optional 与 required 相反、
  • :invalid 其值与 pattern 属性给出的模式不匹配的字段,或不是有效电子邮件个税,URL 格式等、
  • :valid 与 invalid 相反
    <style>
     input : focus{
        background-color : greenyellow;
     }
     textarea : disabled{
       background-color : #ccc;
       border-color : #999;
       color : #666;
      }
    </style>

     

posted @ 2021-08-24 11:46  sam-zh  阅读(328)  评论(0编辑  收藏  举报