我对hover最常使用的时候就是跟display或者overflow打配合,做到隐藏二维码,购物车内容之类的东西,但有一次仿写小米官网的时候出现了问题,我使用display对二维码进行隐藏,但在hover内设置显示的时候却没有显示出来,反反复复考虑了几天,我一直在检查是否是权重值的问题,或者hover本身具有某种限制,最后碰巧发现原来是惯性思维导致的问题。
1.基本样式
html部分:
页面部分:

css部分:


但是效果与我的预期不一样,它只显示了三角,并没有二维码

2.解决方法
我把:hover移到了.download的父级元素,成功地达到了预期要求
css部分:

效果:

3.总结
解决后我还没反应过来,为什么hover放到父元素后面就可以了,文档里也没写hover对跟谁还有要求,我一直很多都是放在div后面的,也没出问题。再看了下结构才发现,原来这个.download在body中没有可定位的范围,也就是说我没办法把鼠标放在它上面,所以也就无法显示。
我写完一个模块通常都会忘了它,从新开始下一个模块,也就导致我忽视了结构这个问题,以至于出现这种错误,希望能给大家带来帮助,也给自己提个醒。

在前端开发中,遇到一个CSS hover使用问题,原本用于隐藏和显示内容的技巧失效。问题源于将`:hover`应用于子元素,而非父元素。通过调整CSS选择器,将`:hover`应用到父级,成功解决了显示问题。此案例提醒开发者注意元素的定位和交互逻辑,避免结构疏忽导致的错误。
145

被折叠的 条评论
为什么被折叠?



