react-star-rate

React Star Rate

</a>

NPM Version minzipped size Build Status


Lightweight, customizable star ratings component for React.


Created by Raymon Zhang
React Star Rate


Features

Table of contents

Example

You can visit the example here:
View on CodeSandbox

Installation

With yarn

yarn add react-star-rate

With NPM

npm install react-star-rate

Getting Started

You can add React Stars Rating to your project using the <StarsRating /> component.

import { useState } from 'react';

import StarsRating from 'react-star-rate';

const App = () => {
  const [value, setValue] = useState(0);
  return (
    <div>
      <StarsRating
        value={value}
        onChange={value => {
          setValue(value);
        }}
      />
    </div>
  );
};

Props

Name Type Default Description
allowClear boolean true Allow the value to be reset when clicked again
allowHalf boolean true Allow half of the star to be selected
autoFocus boolean - Automatically focus the element
classNamePrefix string "react-star-rate" The components will have classNames with the given prefix
count number 5 Number of stars
defaultValue number 0 The default value of the stars. Should be the same as the default useState value
direction string "ltr" The direction of the selected stars. Either "ltr" or "rtl"
disabled boolean false Disable the rating element
onBlur function - Will be triggered on blur
onChange function (value) => {} Will be triggered on change of value
onFocus function - Will be triggered on focus
onHoverChange function (value) => {} Will be triggered on hover
style object {} Custom styles. See styling
symbol string "★" The symbol to be displayed
tabIndex number 0 The tab index of the stars container
value number - Controlled value of the component

Styling

Style Object

Each component inside the StarsRating component is keyed and ships with default styles. You can apply custom styles by accessing the key on the style prop.

Style Keys

With CSS

You can also apply custom styles using CSS Stylesheets. The classnames are determined with the classNamePrefix prop (defaults to "react-star-rate").

Classnames

License

MIT Licensed. Copyright (c) 2021-present, Raymon Zhang.