実施原則メイングラフィックは、背景と前景の 2 つの要素で構成されています。次のサンプルコードでは、背景要素は疑似要素 背景要素の 前景要素の 1. メイン要素の <図> <img src='./man.png' alt='イルマ'> </図> 要素 形 { --hov: 0; --not-hov: calc(1 - var(--hov)); 表示: グリッド; 自分自身を配置: 中心; マージン: 0; パディングトップ: 5%; 変換: scale(calc(1 - .1*var(--not-hov))); オーバーフロー: 非表示; 境界線の半径: 0 0 クランプ(4em, 20vw, 15em) クランプ(4em, 20vw, 15em); } 図::before、図画像{ グリッドエリア: 1/1; place-self: 終了センター; } 図::前{ コンテンツ: ""; パディング: クランプ(4em, 20vw, 15em); 境界線の半径: 50%; 背景: url('./bg.png') 50%/カバー; } 図:ホバー{ --hov: 1; } 画像 { 幅: calc(2*clamp(4em, 20vw, 15em)); 境界線の半径: クランプ(4em, 20vw, 15em); 変換: translateY(calc((1 - var(--hov))*10%)) scale(calc(1.25 + .05*var(--hov))); } 2. <図> <img src='./man.png' alt='イルマ'> </図> スタイルは基本的に最初のものと同じで、 形 { --hov: 0; --not-hov: calc(1 - var(--hov)); 表示: グリッド; 自分自身を配置: 中心; マージン: 0; パディングトップ: 5%; 変換: scale(calc(1 - .1*var(--not-hov))); クリップパス: inset(0 round 0 0 クランプ(4em, 20vw, 15em) クランプ(4em, 20vw, 15em)); } 図::before、図画像{ グリッドエリア: 1/1; place-self: 終了センター; } 図::前{ コンテンツ: ""; パディング: クランプ(4em, 20vw, 15em); 境界線の半径: 50%; 背景: url('./bg.png') 50%/カバー; } 図:ホバー{ --hov: 1; } 図:hover::before { ボックスの影: 1px 1px 10px rgba(0, 0, 0, .3); } 画像 { 幅: calc(2*clamp(4em, 20vw, 15em)); 境界線の半径: クランプ(4em, 20vw, 15em); 変換: translateY(calc((1 - var(--hov))*10%)) scale(calc(1.25 + .05*var(--hov))); } 完全な例 <h2>overflow: hidden を使用する</h2> <図> <img src='./man.png' alt='イルマ'> </図> <h2>clip-path: path() メソッドを使用する</h2> <図> <img src='./man.png' alt='イルマ'> </図> 体 { 表示: グリッド; 背景: #FDFC47; 背景: -webkit-linear-gradient(右、#24FE41、#FDFC47); 背景: 線形グラデーション(右、#24FE41、#FDFC47); } 形 { --hov: 0; --not-hov: calc(1 - var(--hov)); 表示: グリッド; 自分自身を配置: 中心; マージン: 0; パディングトップ: 5%; 変換: scale(calc(1 - .1*var(--not-hov))); } 図:n番目の型(1) { オーバーフロー: 非表示; 境界線の半径: 0 0 クランプ(4em, 20vw, 15em) クランプ(4em, 20vw, 15em); } 図:n番目の型(2) { クリップパス: inset(0 round 0 0 クランプ(4em, 20vw, 15em) クランプ(4em, 20vw, 15em)); } 図、図画像 { 遷移: transform 0.2s イーズインアウト; } 図::before、図画像{ グリッドエリア: 1/1; place-self: 終了センター; } 図::前{ パディング: クランプ(4em, 20vw, 15em); 境界線の半径: 50%; 背景: url('./bg.png') 50%/カバー; コンテンツ: ""; 遷移: 0.25 秒の線形。 } 図:ホバー{ --hov: 1; } 図:hover::before { ボックスの影: 1px 1px 10px rgba(0, 0, 0, .3); } 画像 { 幅: calc(2*clamp(4em, 20vw, 15em)); 境界線の半径: クランプ(4em, 20vw, 15em); 変換: translateY(calc((1 - var(--hov))*10%)) scale(calc(1.25 + .05*var(--hov))); } 純粋な CSS でホバー画像のポップアウト効果を実現する方法についての記事はこれで終わりです。より関連性の高い CSS コンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後も 123WORDPRESS.COM を応援していただければ幸いです。 |
<<: 1 つの記事で Apache Avro データを解析する
>>: Vue プロジェクトでの支払い機能の実装 (WeChat 支払いと Alipay 支払い)
目次1. 需要2. データベース設計3.Javaバックグラウンド構成の実装4. WeChatアプレッ...
まさか、2021年になってもTypeScriptについて聞いたことがない人がいるなんて?プロジェクト...
目次setState は同期ですか、それとも非同期ですか?カスタム合成イベントと React フック...
2008年5月12日に四川省汶川市で発生した地震により、多くの命が失われ、遺憾なことと存じます。国務...
1. 準備1.1 Pythonインストールパッケージをダウンロードします(注:Pythonバージョン...
VMに慣れた後、BOXに切り替えるのは少し異なります。たとえば、コピーネットワークカードを2枚使って...
この記事では、ネイティブ JS で実装された複合モーションを紹介します。複合モーションとは、異なる属...
<br />今日、新しくなった ChinaUI.com の Web サイトを見たのですが...
序文Mac システムのターミナルでファイルの権限を変更するには、Linux の chmod コマンド...
序文DBA として、仕事中に MySQL マスターとスレーブの同期遅延の問題に遭遇することがよくあり...
nginx をリバース プロキシとして使用する場合、リクエストをそのまま次のサービスに転送するだけで...
セル - 表の内容 セルの余白 (表の余白) (cellpadding) - セルの外側の距離を表し...
目次01 レプリカセットアーキテクチャ02 MySQL Shellの紹介とインストール03 My...
まず実装手順について説明します。最終結果 2. コードの実装HTML部分 <div class...
モバイル ブラウザは、Web ページを仮想の「ウィンドウ」(ビューポート) に配置します。このウィン...