答案:通过HTML、CSS和JavaScript实现可点击评分的星星组件,支持悬停预览与选中状态。1. HTML用data-value标记分数;2. CSS设置默认颜色及悬停高亮;3. JS监听鼠标事件,更新active状态与显示分数;4. 可扩展半星、只读或封装复用。

实现一个简单的评分组件,可以通过点击星星来选择分数,支持鼠标悬停效果和自定义评分数值。以下是使用原生 JavaScript 和简单 HTML/CSS 构建的评分组件示例。
1. HTML 结构
创建一个容器,包含若干代表星星的元素:
当前评分:0
2. CSS 样式
让星星排列成一行,设置默认颜色和悬停效果:
.rating {
font-size: 30px;
color: #ddd;
user-select: none;
}
.rating span {
cursor: pointer;
transition: color 0.2s;
}
.rating span:hover,
.rating span.active {
color: orange;
}
3. JavaScript 功能逻辑
添加交互行为:悬停预览、点击选中评分:
const ratingEl = document.getElementById('rating');
const valueDisplay = document.getElementById('rating-value');
let currentRating = 0;
mallcloud商城基于SpringBoot2.x、SpringCloud和SpringCloudAlibaba并采用前后端分离vue的企业级微服务敏捷开发系统架构。并引入组件化的思想实现高内聚低耦合,项目代码简洁注释丰富上手容易,适合学习和企业中使用。真正实现了基于RBAC、jwt和oauth2的无状态统一权限认证的解决方案,面向互联网设计同时适合B端和C端用户,支持CI/CD多环境部署,并提
// 更新显示的高亮状态
function updateStars(rating) {
Array.from(ratingEl.children).forEach(star => {
if (parseInt(star.dataset.value)
star.classList.add('active');
} else {
star.classList.remove('active');
}
});
}
// 鼠标悬停效果
ratingEl.addEventListener('mouseover', function(e) {
if (e.target.tagName === 'SPAN') {
updateStars(parseInt(e.target.dataset.value));
}
});
// 鼠标离开时恢复到当前评分
ratingEl.addEventListener('mouseout', function() {
updateStars(currentRating);
});
// 点击设置评分
ratingEl.addEventListener('click', function(e) {
if (e.target.tagName === 'SPAN') {
currentRating = parseInt(e.target.dataset.value);
valueDisplay.textContent = `当前评分:${currentRating}`;
}
});
4. 使用说明与扩展建议
这个评分组件轻量且易于集成。你可以根据需要进行以下增强:
- 支持半星评分(通过更复杂的 DOM 或 SVG 实现)
- 添加只读模式
- 封装为可复用函数或类,方便多个实例使用
- 绑定事件回调,比如提交评分
基本上就这些,不复杂但足够实用。










