CSS ヒント: トランジションを使用してホバー状態を保持する

青灯夜游
リリース: 2022-09-27 14:01:48
転載
2407 人が閲覧しました

ホバー状態を保持するにはどうすればよいですか?以下の記事ではJavaScriptを使わずにホバー状態を保持する方法を紹介していますので、ご参考になれば幸いです。

CSS ヒント: トランジションを使用してホバー状態を保持する

通常、ホバーでは状態を保存できません。追加のスタイルは、マウスを移動するとトリガーされ、マウスを移動すると復元されます。

el:hover{ color: red }
ログイン後にコピー
ログイン後にコピー

これは、hoverのステータスを保持する必要がある場合は、JSに頼る必要があることを意味します。たとえば、次のようなランキング効果があります。某アカデミーのホームページ

Kapture 2022-09-26 at 18.37.28

ここでの主なインタラクションは次のとおりです

  • マウスをスライドさせて選択状態をトリガーします

  • 最後に選択した状態は、マウスをリストの外に移動した後も残ります (強調を追加)

  • デフォルト リストの最初の項目が選択されています

現在の公式 Web サイトの実装もJSを通じて実装されていますが、実際にはCSSを通じてのみ完全に実現できます。transitionの小さな遅延が必要です。テクニックを見てみましょう。 [推奨学習:css ビデオ チュートリアル]

1. マウスをスライドさせて選択状態をトリガーします

すべてはレイアウトから切り離せません。

リストは次のようだと仮定します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(); } .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%); }
ログイン後にコピー

結果は次のようになります

CSS ヒント: トランジションを使用してホバー状態を保持する

ここでhover

.item:hover .title{ color: rebeccapurple; } .item:hover .sumary{ height: 40px; } .item.item:hover::before{ opacity: 1; }
ログイン後にコピー

の効果を追加します

Kapture 2022-09-17 at 13.12.45

#非常に通常のhover効果、特に何もありませんが、退去後に最後の状態を維持するにはどうすればよいですか?次に、

2 をお読みください。hover

のステータスを保持するhoverの保持ステータスを達成するには、このような小さなトリックを使用する必要があります。

たとえば、hoverスタイルを要素に追加します

el:hover{ color: red }
ログイン後にコピー
ログイン後にコピー

Kapture 2022-09-17 at 13.18.58

この要素に遅延を追加する場合

el{ transition-delay: 1s; }
ログイン後にコピー

その後、マウスが出入りするときに遅延が発生します

Kapture 2022-09-17 at 13.20.43

次に、hover

el:hover{ color: red; transition-delay: 0s; }
ログイン後にコピー
のときに遅延をキャンセルします。

そうすると、マウスは移動するときはすぐに反応しますが、移動するときはまだ遅延が発生します。

Kapture 2022-09-17 at 13.24.09

遅延がある場合は、これは誰もが理解していると思います。

el{ transition-delay: 9999s; }
ログイン後にコピー

などの十分な大きさに設定すると、マウスを外した後、元の状態に変わる前に9999sを通過する必要があります。これは ## を保持するのと同じです。 #hoverstate

Kapture 2022-09-17 at 13.28.42

原理は次のとおりです、実際のアプリケーションを見てみましょう

3. マウスを移動した後、リストでは、最後に選択した状態が引き続き保持されます。

上記の原則に従って、

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を単独で使用して細部などを制御します。効果は次のとおりです

Kapture 2022-09-26 at 20.02.53##このようにして、マウスが離れた後、前の状態がまだ保持されています。ただし、すべてではなく、最後の 1 つだけを保持する必要があります。

这里需要换一种思路,可以这么做,鼠标在移入整个列表的时候就清除所有的状态,这样就只有当前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触发的,效果如下

Kapture 2022-09-17 at 13.54.53

四、默认列表的第一项为选中态

下面来实现最后一个功能。

这个相对而言比较容易,需要用到:first-child伪类,可以匹配到第一个元素。

不过需要考虑的是优先级的问题,这个是默认状态,权限应该是最低的,其他hover样式都应该可以覆盖它,所以可以放在最前面,如下

/* 初始状态(第一个选中) */ .item:first-child .sumary{ height: 40px; } .item:first-child .title{ color: rebeccapurple; } .item:first-child::before{ opacity: 1; } /* 清除所有hover */ /* 每一项hover */
ログイン後にコピー

这样就完美实现了文章开头的效果

Kapture 2022-09-17 at 14.04.17

由于是 CSS 实现,多个列表也是完全复用的

Kapture 2022-09-26 at 20.22.33.gif

完整代码可以查看线上 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会越来越美好

(学习视频分享:css视频教程web前端

以上がCSS ヒント: トランジションを使用してホバー状態を保持するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:segmentfault.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
関連するチュートリアル
人気のおすすめ
最新のコース
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!