This is the React InstantSearch v7 documentation.
If you’re upgrading from v6, see the upgrade guide.
If you were using React InstantSearch Hooks,
this v7 documentation applies—just check for necessary changes.
To continue using v6, you can find the archived documentation.
Signature
Import
JavaScript
About this widget
<HitsPerPage>
is a widget that displays a menu of options to change the number of results per page.
If you only want to configure the number of hits per page without displaying a widget,
you can use the <Configure>
widget with the hitsPerPage
search parameter.
You can also create your own UI with
useHitsPerPage
.Examples
JavaScript
Props
The list of available options, with each item:
label
. The label to display in the option.value
. The number of hits to display per page.default
. The default hits per page on first search.
transformItems
A function that receives the list of items before they are displayed.
It should return a new array with the same structure.
Use this to transform, filter, or reorder the items.The function also has access to the full
results
data,
including all standard response parameters
and parameters from the helper,
such as disjunctiveFacetsRefinements
.The CSS classes you can override and pass to the widget’s elements.
It’s useful to style widgets with class-based CSS frameworks like Bootstrap or Tailwind CSS.
root
. The root element of the widget.select
. Theselect
element.option
. Theoption
element.
JavaScript
Any
<div>
prop to forward to the root element of the widget.JavaScript
Hook
React InstantSearch let you create your own UI for the<HitsPerPage>
widget with useHitsPerPage
.
Hooks provide APIs to access the widget state and interact with InstantSearch.
The useHitsPerPage
Hook accepts parameters and returns APIs.
It must be used inside the <InstantSearch>
component.
Usage
First, create your React component:JavaScript
JavaScript
Parameters
Hooks accept parameters. You can either pass them manually or forward props from a custom component.When passing functions to Hooks, ensure stable references to prevent unnecessary re-renders.
Use
useCallback()
for memoization.
Arrays and objects are automatically memoized.The list of available options, with each item:
label
. The label to display in the option.value
. The number of hits to display per page.default
. The default hits per page on first search.
transformItems
A function that receives the list of items before they are displayed.
It should return a new array with the same structure.
Use this to transform, filter, or reorder the items.The function also has access to the full
results
data,
including all standard response parameters
and parameters from the helper,
such as disjunctiveFacetsRefinements
.APIs
Hooks return APIs, such as state and functions. You can use them to build your UI and interact with React InstantSearch.The list of items the widget can display, with each item:
label: string
. The label to display in the option.value: number
. The number of hits to display per page.isRefined: boolean
. Indicates if the item is the current refined value.
Indicates whether the search can be refined.
JavaScript
Sets the number of hits per page and triggers a search.
JavaScript
Generates a URL of the next search state.
JavaScript