<input type="search">

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.

search 类型的 <input> 是专为用户输入查询文本而设计的字段。功能上与 text 输入相同,但是根据用户代理不同,可能会有不同的样式表现。

尝试一下

代表搜索字段中值的字符串。
事件 changeinput
支持的通用属性 autocompletelistmaxlengthminlengthpatternplaceholderrequiredsize
IDL 属性 value
DOM 接口 HTMLInputElement
方法 select()setRangeText()setSelectionRange()

value 属性包含一个代表搜索字段中含有值的字符串。你可以使用 JavaScript 的 HTMLInputElement.value 属性获取该值。

js
searchTerms = mySearch.value;

如果没有针对该 input 的验证约束(请参见验证方式),该值可以是任何文本字符串或空字符串("")。

其他属性

除了可在所有 <input> 上应用的属性(无论其类型)之外,搜索字段输入还支持以下属性。

list

list 属性指定了一个 <datalist> 元素的 id,用来提供输入建议。<datalist> 提供了一个预定义的值列表,向用户建议这个输入。列表中任何与 type 不兼容的值都不包括在建议选项中。所提供的值是建议,不是要求:用户可以从这个预定义的列表中选择,或者提供不同的值。

maxlength

用户可以在搜索字段中输入的最大字符数(UTF-16 代码单元)。必须为 0 或更高的整数。如果未指定 maxlength 或指定了无效值,则搜索字段没有最大长度。此值还必须大于或等于 minlength 的值。

如果输入到字段中的文本的长度大于 maxlength UTF-16 代码单元的长度,则输入无法通过约束验证

minlength

用户可以在搜索字段中输入的最小字符数(UTF-16 代码单元)。该值必须是小于或等于 maxlength 指定的值的非负整数值。如果未指定 minlength 或指定了无效值,则搜索输入没有最小长度。

如果在字段中输入的文本的长度小于 minlength UTF-16 代码单元的长度,则搜索字段将无法通过约束验证

pattern

如果指定了 pattern 属性,为了使 value 通过约束验证,必须满足该属性给定的正则表达式。它必须是 RegExp 类型的有效 JavaScript 正则表达式,并且已在我们的正则表达式指南中进行了说明;在编译正则表达式时指定了 'u' 标志,因此该模式被视为 Unicode 代码点的序列,而不是 ASCII。模式文本周围无需指定正斜杠。

如果模式未指定或无效,则不应用任何正则表达式,并且将完全忽略此属性。

备注: 使用 title 属性指定大多数浏览器将显示为文本的工具提示,以说明与模式匹配的要求。你还应该在附近添加其他说明性文字。

请参照指定模式更多内容和例子。

placeholder

placeholder 属性是一个字符串,可向用户提供有关该字段中需要什么样的信息的简短提示。它应该是一个单词或短语来说明预期的数据类型,而不是说明性消息。文本中不得包含回车符或换行符。

如果控件的内容具有方向(LTRRTL),但需要以相反的方向显示占位符,则可以使用 Unicode 双向算法来格式化字符,从而覆盖原有占位符的方向;请参见如何针对双向文本使用 Unicode 控制符获取更多信息。

备注: 尽可能避免使用 placeholder 属性。它在语义上没有其他解释表单的方式有用,并且可能导致内容出现意外的问题。请参见 <input> 标签以获取更多信息。

readonly

一个布尔属性,如果存在,则表示该字段不能由用户编辑。但是,仍可以通过 JavaScript 代码直接设置 HTMLInputElementvalue 属性来更改。

备注: 因为只读字段不能有值,所以 required 对指定了 readonly 属性的输入没有任何影响。

size

size 属性是一个数字值,指示输入字段应有多少个字符宽。该值必须是一个大于零的数字,默认值是 20。由于字符宽度各不相同,这可能是也可能不是精确的,不应依赖于此;结果输入可能比指定的字符数更窄或更宽,这取决于字符和字体(正在使用的 font 设置)。

这并限制用户可以在该字段中输入多少个字符,仅能指定一次可以看到多少个。要设置输入数据长度的上限,请使用 maxlength 属性。

spellcheck

spellcheck 是一个全局属性,用于指示是否启用元素的拼写检查。它可以用于任何可编辑的内容,但是这里我们考虑在 <input> 元素上使用 spellcheck 的细节。 spellcheck 的允许值为:

false

禁用此元素的拼写检查。

true

对此元素启用拼写检查。

""(空字符串)或空值

遵循元素的默认行为进行拼写检查。这可能基于父元素 spellcheck 设置或其他因素。

如果输入字段没有设置 readonly 属性且未禁用,则可以启用拼写检查。

如果用户代理的首选项覆盖了设置,则通过读取 spellcheck 返回的值可能无法反映控件中拼写检查的实际状态。

非标准属性

以下非标准属性在某些浏览器上对搜索输入字段也可用。一般来说,除非万不得已,否则你应该避免使用它们。

autocorrect

Safari 扩展,autocorrect 属性是一个字符串,它指示在用户编辑此字段时是否激活自动更正。允许的值为:

on

启用拼写错误的自动更正,以及配置文本替换(如果已配置)的处理。

off

禁用自动更正和文本替换。

incremental

布尔值属性 incremental 是 WebKit 和 Blink 的扩展(因此被 Safari、Opera、Chrome 等支持)。如果制定了它,它会告诉用户代理将输入作为实时搜索进行处理。当用户编辑字段的值时,用户代理将 search 事件发送到代表搜索框的 HTMLInputElement 对象。这允许你的代码在用户编辑搜索时实时更新搜索结果。

如果没有指定 incremental ,则仅当用户显式启动搜索时(例如,在编辑字段时按 EnterReturn )才发送 search 事件。

search 事件受速率限制,因此发送事件的频率不会超过实现定义的间隔。

mozactionhint

Mozilla 扩展,它提供了一个提示,提示用户在编辑字段时按 EnterReturn 键将采取何种操作。

此属性已经废弃:请使用全局属性 enterkeyhint 作为替代。

results

results 属性是一个数字值(仅受 Safari 支持),可让你覆盖要在 <input> 元素原生提供的先前搜索查询的下拉菜单中所显示的最大条目数。

该值必须是非负十进制数字。如果未提供或给出了无效值,则使用浏览器的默认最大条目数。

使用搜索输入

search 类型的 <input> 元素与 text 类型的元素非常相似,不同之处在于它们专门用于处理搜索条目。它们的行为基本相同,但是用户代理可以选择与默认样式不同的样式(当然,站点可以使用样式表向其应用自定义样式)。

基本示例

html
<form>
  <div>
    <input type="search" id="mySearch" name="q" />
    <button>搜索</button>
  </div>
</form>

如下:

q 是搜索输入中最常用的 name 值,尽管不是强制性的。提交后,发送到服务器的键值对数据将为 q=searchterm

备注: 一定要记住为你的 input 设置 name,否则不会提交任何内容。

搜索类型和文本类型之间的差异

主要的基本区别在于浏览器处理它们的方式。首先要注意的是,某些浏览器显示一个十字图标,如果需要,可以单击该十字图标以立即删除搜索词。在 Chrome 中当按下 escape 键时也会触发这个动作。以下屏幕截图来自 Chrome:

Focused search input, with focus ring, with the text 'cats'. There is an x icon in the input abutting the right side.

此外,现代浏览器还倾向于自动存储先前在各个域中输入的搜索词,在该域的搜索输入中执行后续搜索时,这些搜索词会作为自动完成选项出现。这有助于随着时间的流逝倾向于在相同或相似搜索查询上进行搜索的用户。此屏幕截图来自 Firefox:

An input in error state with a red focus ring. The user has entered the letter 'h'. A pop-up selection list is open directly under the input box with two options: hello and hermansje.现在,让我们看看可以应用于搜索表单的一些有用的技巧。

设置占位符

可以在搜索输入中提供一个有用的占位符,使用 placeholder 属性来提示要做什么。看下面的示例:

html
<form>
  <div>
    <input type="search" id="mySearch" name="q" placeholder="站内搜索..." />
    <button>搜索</button>
  </div>
</form>

可以在下面看到占位符的呈现方式:

搜索表单标签和无障碍

搜索表单的一个问题是它们的无障碍性。常见的设计惯例是不为搜索字段提供标签(尽管可能会有放大镜或类似图标),因为由于放置位置的原因,搜索表单的目的通常对于视力正常的用户而言相当明显(这个例子展示了一个典型的模式)。

但是,这可能会使屏幕阅读器用户感到困惑,因为它们不会对搜索输入内容有任何口头指示。解决此问题而不会影响你的视觉设计的一种方法是使用 WAI-ARIA 功能:

  • <form> 元素上, search 值的 role 属性向屏幕阅读器用户声明该表单是搜索表单。
  • 还可以在 <input> 本身使用 aria-label 属性。这应该是一个描述性的文本标签,屏幕阅读器会读出该标签;它用作 <label> 的非可视等效项。

让我们看一个例子:

html
<form role="search">
  <div>
    <input
      type="search"
      id="mySearch"
      name="q"
      placeholder="站内搜索..."
      aria-label="在全站内容中搜索" />
    <button>搜索</button>
  </div>
</form>

你可以在下面看到它的呈现方式:

与上一个示例没有视觉上的区别,但是屏幕阅读器用户可以获得更多可用信息。

备注: 有关此类辅助功能的更多信息,请参见 Signposts/Landmarks

输入框元素物理大小

可以使用 size 属性来控制输入框的尺寸。使用它,可以指定输入框一次可以显示的字符数。例如,在此示例中,搜索框为 30 个字符宽:

html
<form>
  <div>
    <input
      type="search"
      id="mySearch"
      name="q"
      placeholder="站内搜索..."
      size="30" />
    <button>搜索</button>
  </div>
</form>

结果是这个更宽的输入框:

验证方式

<input> 元素的 search 类型具有与常规文本 text 输入相同的验证功能。通常,不太可能希望对搜索框使用验证功能。在许多情况下,应该允许用户搜索任何内容,但是有几种情况需要考虑,例如搜索已知格式的数据。

备注: HTML 表单验证不能替代服务器脚本,以确保输入的数据格式正确。对于某人来说,对 HTML 进行调整以使其绕过验证或完全删除验证太容易了。有人也可以完全绕开你的 HTML 并将数据直接提交到你的服务器。如果服务器端代码无法验证接收到的数据,则当将格式不正确的数据(或太大,类型错误的数据等等)输入数据库时,灾难可能会发生。

样式注意事项

有一些有用的伪类可用于设置有效/无效表单元素的样式::valid:invalid。在本节中,我们将使用以下 CSS,它将在包含有效值的输入旁边放置一个复选标记(勾号),并在包含无效值的输入旁边放置一个叉号。

css
input:invalid ~ span::after {
  content: "✖";
  padding-left: 5px;
  position: absolute;
}

input:valid ~ span::after {
  content: "✓";
  padding-left: 5px;
  position: absolute;
}

该技巧还需要将 <span> 元素放置在 form 元素之后,该 form 元素充当图标的持有者。这是必要的,因为某些浏览器上的某些输入类型不能很好地显示直接位于其后的图标。

让输入框必填

你可以使用 required 属性令输入一个值成为允许提交表单前的必要条件:

html
<form>
  <div>
    <input
      type="search"
      id="mySearch"
      name="q"
      placeholder="站内搜索..."
      required />
    <button>搜索</button>
    <span class="validity"></span>
  </div>
</form>

如下所示:

另外,如果尝试在未输入搜索词的情况下提交表单,浏览器将显示一条消息。以下示例来自 Firefox:

form field with attached message that says Please fill out this field

当尝试使用输入中包含的不同类型的无效数据提交表单时,将显示不同的消息;请参阅以下示例。

输入值长度

你可以使用 minlength 属性为输入的值指定最小长度(以字符为单位);同样,使用 maxlength 设置输入值的最大长度。

下面的示例要求输入的值的长度为 4–8 个字符。

html
<form>
  <div>
    <label for="mySearch">查找用户</label>
    <input
      type="search"
      id="mySearch"
      name="q"
      placeholder="用户 ID 的长度为 4-8 个字符"
      required
      size="30"
      minlength="4"
      maxlength="8" />
    <button>查找</button>
    <span class="validity"></span>
  </div>
</form>

如下所示:

如果尝试提交少于 4 个字符的表单,则会收到相应的错误消息(不同的浏览器会有所不同)。如果尝试输入超过 8 个字符,浏览器将不允许你这样做。

指定模式

你可以使用 pattern 属性指定一个正则表达式,输入值必须遵循该正则表达式才能被视为有效(请参照使用正则表达式进行验证)。

让我们看一个例子。假设我们想提供一个产品 ID 搜索表格,这些 ID 都是由两个字母和四个数字组成的代码。以下示例对此进行了介绍:

html
<form>
  <div>
    <label for="mySearch">根据 ID 查找产品:</label>
    <input
      type="search"
      id="mySearch"
      name="q"
      placeholder="两个字母接四位数字"
      required
      size="30"
      pattern="[A-z]{2}[0-9]{4}" />
    <button>查找</button>
    <span class="validity"></span>
  </div>
</form>

如下所示:

例子

可以在我们的网站 website-aria-roles 示例中看到一个在上下文中使用搜索表单的一个好例子(试试在线运行它)。

规范

Specification
HTML Standard
# text-(type=text)-state-and-search-state-(type=search)

浏览器兼容性

BCD tables only load in the browser

参见