
本文针对CSS伪元素`:after`在实现星级评分等交互功能时,hover和点击事件无响应的问题,提供详细的解决方案。通过修正CSS样式中的定位和透明度设置,确保伪元素正确响应用户交互,实现预期的动态效果,最终呈现一个功能完善的星级评分组件。
在使用CSS伪元素:after创建交互式元素时,有时会遇到hover和点击事件无法触发的问题。这通常是由于CSS样式设置不当导致的。以下将通过一个星级评分的示例,详细讲解如何解决这个问题。
在提供的代码中,星级评分效果是通过:before和:after伪元素叠加实现的。:before显示默认的星形,:after显示高亮的星形。问题在于:after元素无法正确响应hover和click事件,导致无法实现动态高亮效果。
主要原因在于以下两点:
要解决这个问题,需要对CSS样式进行如下修改:
为label元素添加position: relative;声明:
.rating label {
/* 添加 Position Relative*/
position: relative;
display: block;
cursor: pointer;
width: 50px;
background: #ccc;
}这确保了:after元素相对于label元素进行定位,从而正确覆盖:before元素。
设置:after元素的默认透明度为0:
Facetune
一款在线照片和视频编辑工具,允许用户创建AI头像
109
查看详情
.rating label::after {
content: "★";
position: absolute;
font-family: fontAwesome;
/* 设置默认透明度为 0*/
opacity: 0;
display: block;
font-size: 50px;
color: #1f9cff;
top: 0;
}这使得:after元素在默认情况下是隐藏的,只有在hover或点击时才会显示,从而实现动态高亮效果。
以下是修改后的完整代码:
HTML:
<html> <head> <link href="https://cdn.jsdelivr.net/npm/@fortawesome/<a class="__cf_email__" data-cfemail="51373e3f25302634223e3c347c3723343411672f102f10">[email protected]</a>/css/fontawesome.min.css" rel="stylesheet" /> </head> <body> <div id="23"></div> </body> </html>
J*aScript:
var numbersDiv = document.getElementById("23");
var aa = document.createElement("div");
aa.className = "rating";
for (let i = 0; i < 5; i++) {
var tempStar = document.createElement("input");
tempStar.setAttribute("type", "radio");
tempStar.setAttribute("name", "star");
var tempStarId = "star" + i;
tempStar.id = tempStarId;
var tempLabel = document.createElement("label");
tempLabel.setAttribute("for", tempStarId);
aa.appendChild(tempStar);
aa.appendChild(tempLabel);
}
numbersDiv.appendChild(aa);CSS:
.rating {
display: flex;
}
.rating input {
display: none;
}
.rating label {
/* 添加 Position Relative*/
position: relative;
display: block;
cursor: pointer;
width: 50px;
background: #ccc;
}
.rating label::before {
content: "★";
position: relative;
font-family: fontAwesome;
display: block;
font-size: 50px;
color: #101010;
}
.rating label::after {
content: "★";
position: absolute;
font-family: fontAwesome;
/* 设置默认透明度为 0*/
opacity: 0;
display: block;
font-size: 50px;
color: #1f9cff;
top: 0;
}
.rating label:hover::after,
.rating label:hover~label::after,
.rating input:checked~label::after {
opacity: 1;
}通过正确设置position和opacity属性,可以解决CSS伪元素:after不响应hover和点击事件的问题。 理解CSS定位和透明度的概念对于创建复杂的交互式UI组件至关重要。 在实际开发中,应仔细检查CSS样式,确保元素能够正确响应用户交互。
以上就是修复CSS伪元素:after不响应hover或点击事件的问题的详细内容,更多请关注其它相关文章!
# javascript
# 苏州seo推广商家
# 制作网站推广公司
# 厦门推广短视频营销优势
# 锦州网络seo多少钱
# 青岛网站建设推广靠谱
# 相对于
# 主要原因
# 解决问题
# 中文网
# 相关文章
# 情况下
# 背景色
# 解决这个问题
# 两种
# css
# java
# html
# js
# 伪元素
# app
# ai
# cdn
# css样式
# 点击事件
# .net
# 可以根据
# 门户网站建设收益如何
# 贵阳网站建设运营方案
# 排名技术网站百度推广SEO优化
# 政府网站建设依据
# 奉贤区推广网站价格表格
相关栏目:
【
Google疑问12 】
【
Facebook疑问10 】
【
优化推广96088 】
【
技术知识133117 】
【
IDC资讯59369 】
【
网络运营7196 】
【
IT资讯61894 】
相关推荐:
《米姆米姆哈》米姆获取及技能攻略
韩小圈网页版PC端入口 韩小圈网页版官方网站入口
掌握CSS :has() 选择器:父选择器、嵌套限制与常见陷阱解析
学习通网页版个人登录_学习通网页版个人账户登录入口
win11关机几秒又自己开机 Win11关机自动重启问题修复
蛙漫2(台版)正版官网 2025免费网页版分享
优酷官网登录入口电脑版 优酷官网网址入口
谷歌浏览器官网地址整理_谷歌浏览器新版直连2026稳定访问
OTT月报 | 2025年9月智能电视大数据报告
Linux如何优化系统启动流程_Linux启动项优化方案
海棠书屋官方在线书籍入口 海棠书屋文学作品浏览官网链接
如何定制PrimeNG Sidebar的背景颜色
Win10显卡驱动安装失败怎么办 Win10使用DDU彻底卸载驱动【解决】
高效调试PHP大型嵌套数组:JSON序列化与可视化工具实践
顺丰快递单号查询寄件人 顺丰寄件人查询入口
飞飞漫画漫画阅读官网_飞飞漫画漫画阅读官网进入阅读
mysql中外键约束如何使用_mysql FOREIGN KEY操作
抖音作品被限流怎么办 抖音内容优化与流量恢复方法
PDF如何批量加注释_PDF多文件批注高亮操作教程
鲁班大师乓乓皮肤获取方法
晓晓优选app支付宝绑定方法
使用Google服务账号实现Google Drive API无缝集成与文件访问
lol小红书怎么|直播|?lol小红书|直播|是什么意思?
如何快速去除厨房重油污? 2025年最好用的厨房清洁剂推荐
家里的小飞虫总是不断,用什么方法可以彻底根除?
《战地6》反作弊已成功拦截240万次作弊 发售第一周98%比赛没有作弊
Go语言反射机制下访问嵌入结构体中的被遮蔽方法
在Spring Boot Thymeleaf中利用布尔属性实现容器的条件显示
FotoBalloon图片左右镜像教程
精通VS Code多光标编辑以实现闪电般快速的修改
《深林》冬季章节图文攻略
如何在mysql中设计餐饮点餐系统_mysql点餐系统项目实战
海棠阅读登录教程_详细讲解海棠登录操作
《淘宝联盟》推广自己的店铺方法
MongoDB聚合管道:高效统计列表中各项的文档数量
macosmonterey系统外接显示器驱动怎么安装_macosmonterey外接显示器驱动与分辨率调整
京东快递包裹信息查询入口 京东快递官方查询平台入口
如何发挥新媒体矩阵作用?新媒体矩阵怎么搭建?
excel怎么计算平均值 excel平均函数*ERAGE使用教学
电脑视频号|直播|如何分享屏幕
PHP多语言网站的实现:会话管理与翻译函数优化教程
《雅迪智行》用手机开锁方法
向往的生活小游戏启动处_向往的生活小游戏立即启动
可米酷漫画在线阅读入口_ 可米酷漫画官网直达链接
视频转蓝光m2ts格式
J*aScript深度克隆:实现高效、健壮与安全的复杂对象复制
创客贴登录页面入口 创客贴网页版最新网址链接
如何在解析前预检查XML文件的完整性? 比如检查文件大小或特定结束标签
邮政快递寄件查询入口 邮政快递收件查询入口
C++怎么解决数值计算中的精度问题_C++浮点数误差与数值稳定性分析
2025-10-12
运城市盐湖区信雨科技有限公司是一家深耕海外推广领域十年的专业服务商,作为谷歌推广与Facebook广告全球合作伙伴,聚焦外贸企业出海痛点,以数字化营销为核心,提供一站式海外营销解决方案。公司凭借十年行业沉淀与平台官方资源加持,打破传统外贸获客壁垒,助力企业高效开拓全球市场,成为中小企业出海的可靠合作伙伴。