Member-only story
Create a Star Rating Widget with CSS in 9 Steps
data:image/s3,"s3://crabby-images/3e79b/3e79bd721db88507036314b98fdcddcb10e2cfa4" alt=""
Star rating tools are seen on all kinds of apps and websites these days. Who knows — at one point you may be asked to build one as a quick way to collect user feedback.
Below is one way of achieving the star rating effect using pure CSS. You can glance at the finished product below.
Along the way, you’ll learn to use pseudoselectors, the “subsequent siblings” combinator (~
), a few flexbox layout techniques, and a CSS transition.
While this code is Javascript-free, you will ultimately want to use some programming to parse, send, and store the value that the user selects. But for now, let’s dive into the HTML and CSS to see how to build the widget itself.
Step 1: Create one star in the “off” state
First, let’s make just one star with a hollow appearance that serves as our “off” state.
The overall container is a div
container with the class star-rating
.
<div class="star-rating"></div>