Heim > Artikel > Web-Frontend > CSS-Tipp: Verwenden Sie den Übergang, um den Hover-Status beizubehalten
Wie behalte ich den Schwebezustand bei? Im folgenden Artikel erfahren Sie, wie Sie den Hover-Status beibehalten, ohne JavaScript zu verwenden. Ich hoffe, er hilft Ihnen weiter!
Normalerweise kann der Status mit der Maus nicht gespeichert werden. Zusätzliche Stile werden ausgelöst, wenn die Maus hinein bewegt wird, und wiederhergestellt, sobald die Maus heraus bewegt wird.
el:hover{ color: red }
Das bedeutet, dass Sie möglicherweise auf JS
zurückgreifen müssen, wenn Sie den Status von hover
beibehalten müssen. Das Folgende ist beispielsweise der Ranking-Effekt des Hauses Seite einer bestimmten Akademiehover
的状态,可能就不得不借助JS
了,比如下面是某某书院的首页排行榜效果
这里的主要交互有以下几个
鼠标滑过触发选中态
鼠标移出列表后仍然保留上一次的选中态(重点)
默认列表的第一项为选中态
目前官网的实现也是通过JS
实现的,事实上,仅仅通过 CSS
也是可以完全做到的,需要用到transition
延时的一些小技巧,一起看看吧。【推荐学习:css视频教程】
所有的一切都离不开布局。
假设列表HTML
是这样的
只是在休息室里打了个盹儿,一睁眼,竟然穿成了古代目不识丁的乡下胖丫头。 好吃懒做不说,还在村里横行霸道。 十里八乡没人愿意娶她,好不容易买了个金龟婿,大婚之日竟让人逃了。 恶霸老爹一怒之下去道上掳了个夫君给她。 就是……爹你掳的是不是有点不太对呀? * 婚后的苏胖丫很忙。 忙着改造恶霸爹爹与恶霸弟弟。 忙着抢救貌美如花的神将夫君。 忙着养育三个小小恶霸小豆丁。 一不小心,将自己忙成了大燕最位高权重的一品女侯!
【甜爽燃,团宠,玄学】 司扶倾一睁眼,不仅被夺了气运,人人还让她滚出娱乐圈。 重活一次,她只想咸鱼躺,谁知现在圈内人只知拉踩营销,没点真本事,不好好磨炼演技,这样下去还能行?怎么也得收拾收拾。 司扶倾捏了捏手腕,动了。 后来,网上疯狂骂她不自量力倒贴郁曜,造谣她私生活不检点,而—— 国际天后:今天我能站在这里,多亏了倾倾 top1男顶流:离我妹妹远点@郁曜 就连国际运动会官方:恭喜司扶倾拿下第13枚个人金牌,等一个退圈 当天,全网瘫痪。 · 史书记载,胤皇年少成名,八方征战,平天下,安宇内,是大夏朝最年轻的帝王,他完美强大,心怀天下,却因病死于27岁,一生短暂,无妻无妾,无子无孙,是无数人的白月光男神。 无人知晓,他再睁开眼,来到了1500年后。 这一次,他看见了他遥想过的盛世大夏。 · 不久后胤皇身份曝光,司扶倾得知偶像竟然就在身边,她敬佩万分,只想—— 司扶倾:努力奋斗,报效大夏! 胤皇:以身相许 司扶倾:??? 我一心奋发上进你却想要我? · 全能颜巅女神×杀伐清贵帝王 从全网黑到封神顶流,顺便和男神1v1
简单修饰一下
.list{ list-style: none; margin: 0; padding: 0; width: 400px; } .item{ position: relative; padding: 10px 10px 10px 34px; cursor: pointer; counter-increment: num; } .title::before{ content: counter(num) ' '; width: 25px; line-height: 30px; text-align: center; color: #fff; position: absolute; font-size: 14px; font-family: fantasy; left: 4px; background: center/100% 100% url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA8CAMAAAAe9Wm0AAAAbFBMVEUAAACaov2SnPKXnvaXofiyuvuCjPOgqvi4vfiBjPSyuf6Ml/a0u/21vPtte/F/i/WTnfWNmPiyuv6Ik/Zue/GRnPinr/Wfp/Gyuv6Ml/ebo/KTnfOutfqEj/W3vvpue/G/xfd1gvN8iPRodfBFzp+BAAAAF3RSTlMAECA7U2BgdIiTn6Wsvr+/v9Df39/s/o6+GugAAAGPSURBVHjazdZhk4IgEAZgpS6z8iotPEBF8P//x1tJrTxQlrm5uff7MxubLBtF9sQfp+ywjRCJk+zLhPq6SUwuxokhp4/YT1SUVtWam4nSZObImyA2YXHZ022cYsirOzwYoYti7nJzuMOqeHPNvke5jxgP2DRNNqLSMzQQtXjUtv8cBTWiwqOqohcsKikt8ajkHI+4EGjEBWNnNGJ1jUe1Vp9YJLSSeKRkh0eyC0BdEJIBZ5J/h1TA/6SUOgcgjUdaT6gJQA0CjV85jFrq/ZU/UYtA7HFzG5iA1PcOMnbs0b7tU/mcCAhjO/NE52A8jmXKMHYdnukTzE141vhyGWaSTq97ksMQhOnEF8qYFJvXneDO++lU82VznG0giYDppBVzTTvIffdjZSGFVjA2JHeVuRDbopOC6TrJ7GUSx0a1vYGR8u1kQ5krce5hJAUjlRbuRtuyu8GFVopxZ6OtxW5wObU2P3Ewaby+jya6R7UYO+C3xpICbk3NFhptTToaZ6OtzS/WGm39iUdkmdFFv5pvdNPREWjicTcAAAAASUVORK5CYII=); } .title{ margin: 0; padding: 8px 0; font-weight: normal; } .sumary{ margin: 0; overflow: hidden; display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2; color: #666; font-size: 14px; color: 20px; height: 0; } .item::before{ content: ''; position: absolute; inset: 0; border-radius: 8px; opacity: 0; z-index: -1; background: linear-gradient(270deg, rgb(241, 236, 249) 0%, rgba(241, 236, 249, 0) 100%); }
效果如下
现在加上hover
的效果
.item:hover .title{ color: rebeccapurple; } .item:hover .sumary{ height: 40px; } .item.item:hover::before{ opacity: 1; }
效果如下
很正常的hover
效果,没什么特别的,那如何在移出后仍然保留最后的状态呢?接着往下看
hover
的状态实现hover
保留状态需要用到这样一个小技巧。
比如,给一个元素添加hover
样式
el:hover{ color: red }
如果我们给这个元素加一个延时
el{ transition-delay: 1s; }
那么,在鼠标移入和移出时都会有延迟
接着,我们在 hover
的时候取消延时
el:hover{ color: red; transition-delay: 0s; }
那么,在鼠标移入的时候会迅速响应,移出的时候仍然会有延迟
到这里相信大家都明白了吧,如果把延时设置为足够大,比如
el{ transition-delay: 9999s; }
这样鼠标在移出后,需要经历9999s
后才会变为原状,也就相当于保留了hover
状态
原理就是这样,接下来看看实际应用吧
根据上面的原理,我们可以轻松的实现在hover
后保留状态,如下
/* 默认 transition */ .item::before, .item .sumary, .item .title{ transition: 0s 9999s; } /* 每一项hover */ .item:hover .title{ color: rebeccapurple; transition: none; } .item:hover .sumary{ height: 40px; transition: none; } .item.item:hover::before{ opacity: 1; transition: none; }
需要注意的是,由于是transition
,所以所有的状态变化都是需要支持过渡属性的,比如隐藏sumary
这里用的是height: 0
而不是display:none
,还有选中的背景色变化,由于background-image
不支持过渡,所以换成了::before
,然后单独用opacity
Die Hauptinteraktionen hier sind wie folgt
Die Maus gleitet darüber, um den ausgewählten Zustand auszulösen
JS
implementiert kann nur durch CSS
vollständig erreicht werden. Schauen wir uns einige Tipps zur transition
-Verzögerung an. [Empfohlenes Lernen: CSS-Video-Tutorial]🎜HTML
sieht so aus🎜/* 清除所有hover */ .list:hover .title{ transition: none; color: #333; } .list:hover .sumary{ transition: none; height: 0; } .list:hover .item::before{ transition: none; opacity: 0; }🎜Ändern Sie sie einfach🎜
/* 初始状态(第一个选中) */ .item:first-child .sumary{ height: 40px; } .item:first-child .title{ color: rebeccapurple; } .item:first-child::before{ opacity: 1; } /* 清除所有hover */ /* 每一项hover */🎜Der Effekt ist wie folgt🎜🎜 Der Effekt🎜rrreee🎜Der Effekt ist wie folgt🎜🎜🎜🎜Sehr normaler
hover
Effekt, nichts Besonderes. Wie kann dann der letzte Zustand nach dem Auszug beibehalten werden? Dann lesen Sie weiter🎜hover
hover
zu erreichen, müssen Sie einen solchen kleinen Trick anwenden. 🎜🎜Fügen Sie beispielsweise den hover
-Stil zu einem Element hinzu🎜rrreee🎜🎜🎜Wenn wir das geben Element Fügen Sie eine Verzögerung hinzu /000/ 024/8cca7cd39174ae572fc0f05bc84e2bab-6.gif" alt="Kapture 2022-09-17 um 13.20.43" title="Kapture 2022-09-17 um 13.20.43" Load="lazy"/>🎜🎜Dann, Wir sind schweben 🎜rrreee🎜Dann reagiert die Maus beim Einfahren schnell und beim Ausfahren kommt es immer noch zu einer Verzögerung🎜🎜🎜🎜Ich glaube, das versteht jeder. Wenn die Verzögerung auf einen ausreichend großen Wert eingestellt ist, z. B. 🎜rrreee🎜, wird nach dem Herausziehen der Maus 9999s
werden in den ursprünglichen Zustand geändert, was der Beibehaltung des hover
-Status entspricht🎜🎜🎜🎜Das Prinzip ist so, schauen wir uns die eigentliche Anwendung an🎜hover
den Status wie folgt beibehalten hat🎜rrreee🎜Es ist zu beachten, dass sich alle Statusänderungen ändern, da es sich um einen Übergang
handelt müssen Übergangsattribute unterstützen, wie z. B. das Ausblenden von sumary
Hier ist height: 0
anstelle von display:none
und der ausgewählte Hintergrund Die Farbe ändert sich, da background-image
keine Übergänge unterstützt. Deshalb habe ich sie in ::before
geändert und dann nur opacity
zur Steuerung verwendet Einige Details usw. Der Effekt ist wie folgt🎜🎜🎜🎜🎜Auf diese Weise bleibt der vorherige Zustand nach dem Verlassen der Maus erhalten Immer noch reserviert. Aber wir müssen nur das Letzte behalten, nicht alle. Wie gehen wir damit um? 🎜这里需要换一种思路,可以这么做,鼠标在移入整个列表的时候就清除所有的状态,这样就只有当前hover
的选项才会保留下来,有点类似于JS
中的思维,先把所有的.current
都移除,再给当前项添加.current
,实现如下
/* 清除所有hover */ .list:hover .title{ transition: none; color: #333; } .list:hover .sumary{ transition: none; height: 0; } .list:hover .item::before{ transition: none; opacity: 0; }
这样就实现了鼠标移出列表后仍然保留上一次的选中态的功能,有点像单选框的效果,只不过是hover
触发的,效果如下
下面来实现最后一个功能。
这个相对而言比较容易,需要用到:first-child
伪类,可以匹配到第一个元素。
不过需要考虑的是优先级的问题,这个是默认状态,权限应该是最低的,其他hover
样式都应该可以覆盖它,所以可以放在最前面,如下
/* 初始状态(第一个选中) */ .item:first-child .sumary{ height: 40px; } .item:first-child .title{ color: rebeccapurple; } .item:first-child::before{ opacity: 1; } /* 清除所有hover */ /* 每一项hover */
这样就完美实现了文章开头的效果
由于是 CSS 实现,多个列表也是完全复用的
完整代码可以查看线上 demo:CSS keep hover(runjs.work)
以上就是通过纯 CSS
实现保留鼠标滑过样式的全部技巧了,主要还是对transition-delay
的灵活运用,下面总结一下
实现原理的利用transition-delay
,让“还原”的时间足够长,这样就实现了保留hover
状态的效果了
单选效果可以在鼠标移入整个列表的时候就清除所有的状态,这样就只有当前hover
的选项才会保留下来,有点类似于JS
中的思维
需要注意所有属性必须是支持transition
的,比如display:none
就不支持transition
,需要用其他样式代替
当然,整个实现对于 CSS
以及选择器要求是相当高的,实际项目过程中可能并不如 JS
实现来的快,但是,CSS
能够实现的又何必动用 JS
呢?在我看来,JS
就应该回归本职,专心处理数据逻辑交互,视觉方面全部交给CSS
就行了,只是现在CSS
还不够强大,实现需要用到很多奇技淫巧,但是,CSS
现在已经在变得足够强大,比如:has
伪类,相信未来CSS
会越来越美好
Das obige ist der detaillierte Inhalt vonCSS-Tipp: Verwenden Sie den Übergang, um den Hover-Status beizubehalten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!