如何使用CSS制作简单评分星星_hover与伪类结合

来源:站长站作者:马来西亚程序员头衔:程序员
导读:本期聚焦于小伙伴创作的《如何使用CSS制作简单评分星星_hover与伪类结合》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何使用CSS制作简单评分星星_hover与伪类结合》有用,将其分享出去将是对创作者最好的鼓励。

在网页开发中,评分星星是常见的前端交互组件,传统实现方式往往需要依赖JavaScript处理鼠标事件,其实仅通过CSS的hover伪类和伪元素就能完成基础的交互效果,无需编写任何JS代码。这种方式实现简单、性能更好,适合轻量级的评分场景使用。

如何使用CSS制作简单评分星星_hover与伪类结合

实现思路梳理

整个评分星星组件的实现核心分为三个部分:首先是搭建基础的HTML结构,用列表承载每一颗星星;其次通过伪元素生成星星的视觉形状,避免额外添加冗余的HTML标签;最后利用hover伪类结合兄弟选择器,实现鼠标悬停时星星的高亮状态切换。

HTML结构搭建

我们使用无序列表作为星星的容器,每个列表项代表一颗星星,不需要在列表项内部添加额外的内容,所有视觉表现都通过CSS实现。具体结构如下:

<div class="star-rating">
  <ul class="star-list">
    <li class="star-item"></li>
    <li class="star-item"></li>
    <li class="star-item"></li>
    <li class="star-item"></li>
    <li class="star-item"></li>
  </ul>
</div>

基础CSS样式设置

首先重置默认的列表样式,设置星星的排列方式为水平排列,同时定义星星的基础尺寸和颜色。这里我们使用::before伪元素来生成星星的形状,通过边框和旋转属性模拟五角星的外观。

/* 容器样式 */
.star-rating {
  padding: 20px;
}

/* 星星列表重置 */
.star-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 8px;
}

/* 单颗星星基础样式 */
.star-item {
  width: 32px;
  height: 32px;
  position: relative;
  cursor: pointer;
}

/* 用伪元素生成星星形状 */
.star-item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #ddd;
  /* 裁剪为五角星形状 */
  clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
}

结合hover伪类实现交互效果

接下来就是核心的交互实现,我们需要实现两个效果:一是鼠标悬停到某颗星星上时,这颗星星本身高亮;二是鼠标悬停时,这颗星星之前的所有星星也同步高亮。这里需要用到:hover伪类和相邻兄弟选择器~

首先设置鼠标悬停时当前星星的高亮样式:

/* 鼠标悬停时当前星星高亮 */
.star-item:hover::before {
  background-color: #ffc107;
}

然后设置鼠标悬停时,当前星星之前的所有星星也高亮,这里利用兄弟选择器的反向逻辑,先让所有在悬停元素后面的星星保持默认样式,再给前面的星星设置高亮:

/* 鼠标悬停时,当前星星之后的所有星星保持默认 */
.star-item:hover ~ .star-item::before {
  background-color: #ddd;
}

/* 鼠标悬停时,当前星星之前的所有星星高亮 */
.star-list:hover .star-item::before {
  background-color: #ffc107;
}
.star-item:hover ~ .star-item::before {
  background-color: #ddd;
}

上面的样式逻辑是:当鼠标悬停在星星列表上时,先默认把所有星星都设为高亮,然后再把悬停星星之后的星星恢复为默认样式,这样就实现了悬停时前面星星都高亮的效果。

完整代码示例

把所有的代码整合起来,就可以得到一个完整的可运行的评分星星组件:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>CSS评分星星组件</title>
  <style>
    .star-rating {
      padding: 20px;
    }
    .star-list {
      list-style: none;
      padding: 0;
      margin: 0;
      display: flex;
      gap: 8px;
    }
    .star-item {
      width: 32px;
      height: 32px;
      position: relative;
      cursor: pointer;
    }
    .star-item::before {
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: #ddd;
      clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
    }
    .star-item:hover::before {
      background-color: #ffc107;
    }
    .star-list:hover .star-item::before {
      background-color: #ffc107;
    }
    .star-item:hover ~ .star-item::before {
      background-color: #ddd;
    }
  </style>
</head>
<body>
  <div class="star-rating">
    <ul class="star-list">
      <li class="star-item"></li>
      <li class="star-item"></li>
      <li class="star-item"></li>
      <li class="star-item"></li>
      <li class="star-item"></li>
    </ul>
  </div>
</body>
</html>

效果优化建议

如果需要让评分效果更流畅,可以给星星的::before伪元素添加过渡属性,让颜色切换时有渐变效果:

.star-item::before {
  /* 其他原有样式 */
  transition: background-color 0.2s ease;
}

如果需要实现点击后固定评分的效果,可以结合少量的JavaScript给点击的星星添加选中类,再通过CSS设置选中类的样式即可,核心的hover交互依然可以保留。

CSShover伪类评分星星伪元素修改时间:2026-07-05 11:48:27

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。