Component

Search

Search box

A search box with label and attached submit button. The component must be used within an HTML form. The search input has a name=”q” attribute and a customisable ID and NAME.

It can be used on white or on govuk-blue using the on_govuk_blue option.

Markup such as heading tags can be included in the label using the label_text option. Styling is not included in the component for heading tags in labels, however this is what the search results page does.

Search for usage of this component on GitHub.

How it looks (preview) (preview all)

How to call this component

<%= render "govuk_publishing_components/components/search", {} %>

Accessibility acceptance criteria

The search box should:

  • be used inside a form with the role of ‘search’, to indicate it as a search landmark
  • have a clear label to identify the search functionality, which is visible to all users

Other examples

Standard options

This component uses the component wrapper helper. It accepts the following options and applies them to the parent element of the component. See the component wrapper helper documentation for more detail.

  • id - accepts a string for the element ID attribute
  • data_attributes - accepts a hash of data attributes
  • aria - accepts a hash of aria attributes
  • classes - accepts a space separated string of classes, these should not be used for styling and must be prefixed with js-
  • margin_bottom - accepts a number from 0 to 9 (0px to 60px) using the GOV.UK Frontend spacing scale (defaults to no margin)
  • role - accepts a space separated string of roles
  • lang - accepts a language attribute value
  • open - accepts an open attribute value (true or false)
  • hidden - accepts an empty string, ‘hidden’, or ‘until-found’
  • tabindex - accepts an integer. The integer can also be passed as a string
  • dir - accepts ‘rtl’, ‘ltr’, or ‘auto’
  • type - accepts any valid type attribute e.g. ‘button’, ‘submit’, ‘text’
  • rel - accepts any valid rel attribute e.g. ‘nofollow’
  • target - accepts a valid target attribute e.g. ‘_blank’
  • title - accepts any string
  • draggable - accepts a draggable attribute value (“true” or “false”)

Set search value (preview)

<%= render "govuk_publishing_components/components/search", {
  value: "driving licence"
} %>

Stop the label appearing inline (preview)

<%= render "govuk_publishing_components/components/search", {
  inline_label: false
} %>

No border (preview)

Sometimes we don’t need the grey border surrounding the input field, such as when the component is used on a black background

<%= render "govuk_publishing_components/components/search", {
  no_border: true
} %>

For use on govuk blue background (preview)

<%= render "govuk_publishing_components/components/search", {
  on_govuk_blue: true
} %>

Homepage (preview)

For use on the homepage.

<%= render "govuk_publishing_components/components/search", {
  label_text: "Search",
  inline_label: false,
  on_govuk_blue: true,
  label_size: "s",
  homepage: true,
  size: "large"
} %>

Change label text (preview)

<%= render "govuk_publishing_components/components/search", {
  label_text: "Search"
} %>

Set id for search input (preview)

<%= render "govuk_publishing_components/components/search", {
  label_id: "my_unique_id"
} %>

Large version (preview)

<%= render "govuk_publishing_components/components/search", {
  size: "large"
} %>

Large version on mobile only (preview)

<%= render "govuk_publishing_components/components/search", {
  size: "large-mobile"
} %>

Change field name (preview)

To be used if you need to change the default name ‘q’

<%= render "govuk_publishing_components/components/search", {
  name: "my_own_fieldname"
} %>

With aria controls attribute (preview)

The aria-controls attribute is a ‘relationship attribute’ which denotes which elements in a page an interactive element or set of elements has control over and affects.

For places like the finders where the page is updated dynamically after value changes to the input.

<%= render "govuk_publishing_components/components/search", {
  aria_controls: "wrapper"
} %>

With custom button text (preview)

The search box component may be used multiple times on a page – for example, on a guidance and regulation finder results page there is both the sitewide search in the header and also for the specific finder.

To avoid confusion, the text inside the button should be different for each form. This can be done by setting the button_text parameter.

This is visually hidden text – to check for changes use a screen reader or inspect the button element.

<%= render "govuk_publishing_components/components/search", {
  button_text: "Search absolutely everywhere"
} %>

With set label size (preview)

Allows the label text size to be set to xl, l, m, or s. If this is set, then inline_label is automatically set to false.

<%= render "govuk_publishing_components/components/search", {
  label_size: "xl"
} %>

Wrap label inside a heading (preview)

Puts the label inside a heading; heading level defaults to 2 if not set.

(The size of the label can still be set with label_size to appear more like a heading.)

<%= render "govuk_publishing_components/components/search", {
  wrap_label_in_a_heading: true,
  heading_level: 1
} %>

With margin bottom (preview)

Allows the spacing at the bottom of the component to be adjusted.

This accepts a number from 0 to 9 (0px to 60px) using the GOV.UK Frontend spacing scale. It defaults to having no margin bottom.

<%= render "govuk_publishing_components/components/search", {
  margin_bottom: 9
} %>

With margin bottom for the label (preview)

Allows the spacing between the label and the input be adjusted.

Requires inline_label to be false.

This accepts a number from 0 to 9 (0px to 60px) using the GOV.UK Frontend spacing scale. It defaults to having no margin bottom.

<%= render "govuk_publishing_components/components/search", {
  label_margin_bottom: 9,
  inline_label: false
} %>

With custom label class (preview)

Allows adding a custom class to the label of the component.

<%= render "govuk_publishing_components/components/search", {
  label_custom_class: "govuk-heading-xl"
} %>

With corrections disabled (preview)

Allows disabling mobile browser autocorrect features (autocorrect and autocapitalize attributes) on the input field.

Mobile browser autocorrect and text substitution features can conflict with the built in autocorrect features of some search engines, and will frequently correct domain-specific search terms to something that is not what the user intended (for example, correcting “SORN” to “sworn” or “HMRC” to “Hercules”). Capitalisation can also be significant for some search engines such as that currently used by Search API v2.

<%= render "govuk_publishing_components/components/search", {
  disable_corrections: true
} %>