本章描述 <input> 元素的输入类型。

输入类型:text

<input type="text"> 定义供文本输入的单行输入字段:

实例

  1. <form>
  2. First name:<br>
  3. <input type="text" name="firstname">
  4. <br>
  5. Last name:<br>
  6. <input type="text" name="lastname">
  7. </form>

以上 HTML 代码在浏览器中看上去是这样的:

First name:

Last name:

输入类型:password

<input type="password"> 定义密码字段

实例

  1. <form>
  2. User name:<br>
  3. <input type="text" name="username">
  4. <br>
  5. User password:<br>
  6. <input type="password" name="psw">
  7. </form>

以上 HTML 代码在浏览器中看上去是这样的:

User name:

User password:

注释:password 字段中的字符会被做掩码处理(显示为星号或实心圆)。

输入类型:submit

<input type="submit"> 定义提交表单数据至表单处理程序的按钮。

表单处理程序(form-handler)通常是包含处理输入数据的脚本的服务器页面。

在表单的 action 属性中规定表单处理程序(form-handler):

实例

  1. <form action="action_page.php">
  2. First name:<br>
  3. <input type="text" name="firstname" value="Mickey">
  4. <br>
  5. Last name:<br>
  6. <input type="text" name="lastname" value="Mouse">
  7. <br><br>
  8. <input type="submit" value="Submit">
  9. </form>

以上 HTML 代码在浏览器中看上去是这样的:

First name:

Last name:


如果您省略了提交按钮的 value 属性,那么该按钮将获得默认文本:

实例

  1. <form action="action_page.php">
  2. First name:<br>
  3. <input type="text" name="firstname" value="Mickey">
  4. <br>
  5. Last name:<br>
  6. <input type="text" name="lastname" value="Mouse">
  7. <br><br>
  8. <input type="submit">
  9. </form>

Input Type: radio

<input type="radio"> 定义单选按钮。

Radio buttons let a user select ONLY ONE of a limited number of choices:

实例

  1. <form>
  2. <input type="radio" name="sex" value="male" checked>Male
  3. <br>
  4. <input type="radio" name="sex" value="female">Female
  5. </form>

以上 HTML 代码在浏览器中看上去是这样的:

Male
Female

Input Type: checkbox

<input type="checkbox"> 定义复选框。

复选框允许用户在有限数量的选项中选择零个或多个选项。

实例

  1. <form>
  2. <input type="checkbox" name="vehicle" value="Bike">I have a bike
  3. <br>
  4. <input type="checkbox" name="vehicle" value="Car">I have a car
  5. </form>

以上 HTML 代码在浏览器中看上去是这样的:

I have a bike
I have a car

Input Type: button

<input type="button> 定义按钮

实例

  1. <input type="button" onclick="alert('Hello World!')" value="Click Me!">

以上 HTML 代码在浏览器中看上去是这样的:

HTML5 输入类型

HTML5 增加了多个新的输入类型:

  • color
  • date
  • datetime
  • datetime-local
  • email
  • month
  • number
  • range
  • search
  • tel
  • time
  • url
  • week

注释:老式 web 浏览器不支持的输入类型,会被视为输入类型 text。

输入类型:number

<input type="number"> 用于应该包含数字值的输入字段。

您能够对数字做出限制。

根据浏览器支持,限制可应用到输入字段。

实例

  1. <form>
  2. Quantity (between 1 and 5):
  3. <input type="number" name="quantity" min="1" max="5">
  4. </form>

输入限制

这里列出了一些常用的输入限制(其中一些是 HTML5 中新增的):

属性 描述
disabled 规定输入字段应该被禁用。
max 规定输入字段的最大值。
maxlength 规定输入字段的最大字符数。
min 规定输入字段的最小值。
pattern 规定通过其检查输入值的正则表达式。
readonly 规定输入字段为只读(无法修改)。
required 规定输入字段是必需的(必需填写)。
size 规定输入字段的宽度(以字符计)。
step 规定输入字段的合法数字间隔。
value 规定输入字段的默认值。

您将在下一章学到更多有关输入限制的知识。

实例

  1. <form>
  2. Quantity:
  3. <input type="number" name="points" min="0" max="100" step="10" value="30">
  4. </form>

输入类型:date

<input type="date"> 用于应该包含日期的输入字段。

根据浏览器支持,日期选择器会出现输入字段中。

实例

  1. <form>
  2. Birthday:
  3. <input type="date" name="bday">
  4. </form>

您可以向输入添加限制:

实例

  1. <form>
  2. Enter a date before 1980-01-01:
  3. <input type="date" name="bday" max="1979-12-31"><br>
  4. Enter a date after 2000-01-01:
  5. <input type="date" name="bday" min="2000-01-02"><br>
  6. </form>

输入类型:color

<input type="color"> 用于应该包含颜色的输入字段。

根据浏览器支持,颜色选择器会出现输入字段中。

实例

  1. <form>
  2. Select your favorite color:
  3. <input type="color" name="favcolor">
  4. </form>

输入类型:range

<input type="range"> 用于应该包含一定范围内的值的输入字段。

根据浏览器支持,输入字段能够显示为滑块控件。

实例

  1. <form>
  2. <input type="range" name="points" min="0" max="10">
  3. </form>

您能够使用如下属性来规定限制:min、max、step、value。

输入类型:month

<input type="month"> 允许用户选择月份和年份。

根据浏览器支持,日期选择器会出现输入字段中。

实例

  1. <form>
  2. Birthday (month and year):
  3. <input type="month" name="bdaymonth">
  4. </form>

输入类型:week

<input type="week"> 允许用户选择周和年。

根据浏览器支持,日期选择器会出现输入字段中。

实例

  1. <form>
  2. Select a week:
  3. <input type="week" name="week_year">
  4. </form>

输入类型:time

<input type="time"> 允许用户选择时间(无时区)。

根据浏览器支持,时间选择器会出现输入字段中。

实例

  1. <form>
  2. Select a time:
  3. <input type="time" name="usr_time">
  4. </form>

输入类型:datetime

<input type="datetime"> 允许用户选择日期和时间(有时区)。

根据浏览器支持,日期选择器会出现输入字段中。

实例

  1. <form>
  2. Birthday (date and time):
  3. <input type="datetime" name="bdaytime">
  4. </form>

输入类型:datetime-local

<input type="datetime-local"> 允许用户选择日期和时间(无时区)。

根据浏览器支持,日期选择器会出现输入字段中。

实例

  1. <form>
  2. Birthday (date and time):
  3. <input type="datetime-local" name="bdaytime">
  4. </form>

输入类型:email

<input type="email"> 用于应该包含电子邮件地址的输入字段。

根据浏览器支持,能够在被提交时自动对电子邮件地址进行验证。

某些智能手机会识别 email 类型,并在键盘增加 “.com” 以匹配电子邮件输入。

实例

  1. <form>
  2. E-mail:
  3. <input type="email" name="email">
  4. </form>

输入类型:search

<input type="search"> 用于搜索字段(搜索字段的表现类似常规文本字段)。

实例

  1. <form>
  2. Search Google:
  3. <input type="search" name="googlesearch">
  4. </form>

输入类型:tel

<input type="tel"> 用于应该包含电话号码的输入字段。

目前只有 Safari 8 支持 tel 类型。

实例

  1. <form>
  2. Telephone:
  3. <input type="tel" name="usrtel">
  4. </form>

输入类型:url

<input type="url"> 用于应该包含 URL 地址的输入字段。

根据浏览器支持,在提交时能够自动验证 url 字段。

某些智能手机识别 url 类型,并向键盘添加 “.com” 以匹配 url 输入。

实例

  1. <form>
  2. Add your homepage:
  3. <input type="url" name="homepage">
  4. </form>