> ## Documentation Index
> Fetch the complete documentation index at: https://algolia.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Highlight

> Visually highlights matched terms in search results.

<Note>
  This is the **React InstantSearch v7** documentation.
  If you're upgrading from v6, see the [upgrade guide](/doc/guides/building-search-ui/upgrade-guides/react/#migrate-from-react-instantsearch-v6-to-react-instantsearch-v7).
  If you were using React InstantSearch Hooks,
  this v7 documentation applies—just check for [necessary changes](/doc/guides/building-search-ui/upgrade-guides/react/#migrate-from-react-instantsearch-hooks-to-react-instantsearch-v7).
  To continue using v6, you can find the [archived documentation](https://algolia.com/old-docs/deprecated/instantsearch/react/v6/api-reference/instantsearch/).
</Note>

```tsx Signature theme={"system"}
<Highlight
  attribute={string}
  hit={object}
  // Optional props
  highlightedTagName={ReactType}
  nonHighlightedTagName={ReactType}
  separator={ReactNode}
  classNames={object}
  ...props={ComponentProps<'span'>}
/>
```

## Import

```jsx JavaScript icon=code theme={"system"}
import { Highlight } from "react-instantsearch";
```

<Card title="See this widget in action" icon="monitor-play" href="https://instantsearchjs.netlify.app/stories/react/?path=/story/highlight--default" horizontal>
  Preview this widget and its behavior.
</Card>

## About this widget

Displays the [highlighted attributes](/doc/guides/building-search-ui/ui-and-ux-patterns/highlighting-snippeting/react)
of your search results.

The required `hit` prop is an Algolia hit provided by [`<Hits>`](/doc/api-reference/widgets/hits/react),
[`<InfiniteHits>`](/doc/api-reference/widgets/infinite-hits/react) or their Hooks.

You can pass a custom object that doesn't come from Algolia, as long as you follow the expected structure.

```json JSON icon=braces theme={"system"}
{
  "_highlightResult": {
    "attributeName": {
      "value": "..."
    }
  }
}
```

## Examples

```jsx JavaScript icon=code theme={"system"}
import React from "react";
import { liteClient as algoliasearch } from "algoliasearch/lite";
import { InstantSearch, Hits, Highlight } from "react-instantsearch";

const searchClient = algoliasearch("YourApplicationID", "YourSearchOnlyAPIKey");

function Hit({ hit }) {
  return (
    <article>
      <h1>
        <Highlight attribute="name" hit={hit} />
      </h1>
      <p>${hit.price}</p>
    </article>
  );
}

function App() {
  return (
    <InstantSearch indexName="instant_search" searchClient={searchClient}>
      <Hits hitComponent={Hit} />
    </InstantSearch>
  );
}
```

## Props

<ParamField body="attribute" type="keyof THit" required>
  The highlighted attribute.

  Specify a dot-separated value for nested objects, like `actor.name`.

  ```jsx JavaScript icon=code theme={"system"}
  <Highlight
    // ...
    attribute="name"
  />
  ```
</ParamField>

<ParamField body="hit" type="THit" required>
  The original [`hit` object](/doc/guides/building-search-ui/going-further/backend-search/in-depth/understanding-the-api-response#hits)
  provided to the component.
  It contains all the data for that result, including the highlighted parts.

  <Note>The `hit` object must contain a `_highlightResult[attribute].value` property.</Note>

  ```jsx JavaScript icon=code theme={"system"}
  <Highlight
    // ...
    hit={hit}
  />;
  ```
</ParamField>

<ParamField body="highlightedTagName" type="React.ReactType<any>" default="mark">
  The HTML element that wraps the highlight.

  ```jsx JavaScript icon=code theme={"system"}
  <Highlight
    // ...
    highlightedTagName="em"
  />;
  ```
</ParamField>

<ParamField body="nonHighlightedTagName" type="React.ReactType<any>" default="span">
  The HTML element that wraps the non-highlighted parts of the string.

  ```jsx JavaScript icon=code theme={"system"}
  <Highlight
    // ...
    nonHighlightedTagName="div"
  />;
  ```
</ParamField>

<ParamField body="separator" type="React.ReactNode" default=", ">
  The character between each item when the attribute to highlight is an array.

  ```jsx JavaScript icon=code theme={"system"}
  <Highlight
    // ...
    separator=" - "
  />;
  ```
</ParamField>

<ParamField body="classNames" type="Partial<HighlightClassNames>">
  To customize the appearance, override [the appropriate class](/doc/guides/building-search-ui/widgets/customize-an-existing-widget/react#style-your-widgets) in your widget theme.
  It's useful to style widgets with class-based CSS frameworks like [Bootstrap](https://getbootstrap.com) or [Tailwind CSS](https://tailwindcss.com).

  * `root`. The root element of the widget.
  * `highlighted`. The highlighted parts.
  * `nonHighlighted`. The non-highlighted parts.
  * `separator`. The separator elements between highlighted parts.

  ```jsx JavaScript icon=code theme={"system"}
  <Highlight
    // ...
    classNames={{
      root: "MyCustomHighlight",
      separator:
        "MyCustomHighlightSeparator MyCustomHighlightSeparator--subclass",
    }}
  />;
  ```
</ParamField>

<ParamField body="...props" type="React.ComponentProps<'span'>">
  Any `<span>` prop to forward to the root element of the widget.

  ```jsx JavaScript icon=code theme={"system"}
  <Highlight
    // ...
    className="MyCustomHighlight"
    title="My custom title"
  />;
  ```
</ParamField>
