我对hover最常使用的时候就是跟display或者overflow打配合,做到隐藏二维码,购物车内容之类的东西,但有一次仿写小米官网的时候出现了问题,我使用display对二维码进行隐藏,但在hover内设置显示的时候却没有显示出来,反反复复考虑了几天,我一直在检查是否是权重值的问题,或者hover本身具有某种限制,最后碰巧发现原来是惯性思维导致的问题。
1.基本样式
html部分:
页面部分:
css部分:
但是效果与我的预期不一样,它只显示了三角,并没有二维码
2.解决方法
我把:hover移到了.download的父级元素,成功地达到了预期要求
css部分:
效果:
3.总结
解决后我还没反应过来,为什么hover放到父元素后面就可以了,文档里也没写hover对跟谁还有要求,我一直很多都是放在div后面的,也没出问题。再看了下结构才发现,原来这个.download在body中没有可定位的范围,也就是说我没办法把鼠标放在它上面,所以也就无法显示。
我写完一个模块通常都会忘了它,从新开始下一个模块,也就导致我忽视了结构这个问题,以至于出现这种错误,希望能给大家带来帮助,也给自己提个醒。