ホバー画像のポップアウトポップアップ効果を実現するための純粋な CSS のサンプルコード

ホバー画像のポップアウトポップアップ効果を実現するための純粋な CSS のサンプルコード

実施原則

メイングラフィックは、背景と前景の 2 つの要素で構成されています。次のサンプルコードでは、背景要素は疑似要素figure::before表され、前景要素はfigure imgで表されます。マウスをfigure要素の上にhoverと、背景要素が大きくなり、前景要素も大きくなり上方に移動することで、視覚的にポップアップ効果を実現します。

背景要素のfigure::before

前景要素のfigure img

1. overflow: hidden使用する

メイン要素のhtml構造は、 figure要素でラップされたimg要素で構成されます。

<図>
  <img src='./man.png' alt='イルマ'>
</図>

要素hoverときの拡大効果と変位効果を制御するために、 cssに 2 つの変数--hov--not-hovが設定されています。背景要素を超えたときに前景要素が切り取られないように、 figure要素にoverflow: hidden追加し、 padding-top: 5%を設定します (オプション: ページのズームに動的に応答するために、 clamp()関数を使用してborder-radius動的に設定します)

形 {
  --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. clip-path: inset()を使用する

<図>
  <img src='./man.png' alt='イルマ'>
</図>

スタイルは基本的に最初のものと同じで、 clip-pathを使用して円形の背景領域をクリップします。

形 {
  --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 支払い)

推薦する

WeChatアプレット開発によりホームページポップアップボックスアクティビティガイダンス機能が実現

目次1. 需要2. データベース設計3.Javaバックグラウンド構成の実装4. WeChatアプレッ...

Vue3+TypeScriptはaxiosをカプセル化し、リクエスト呼び出しを実装します

まさか、2021年になってもTypeScriptについて聞いたことがない人がいるなんて?プロジェクト...

react setStateの詳細な説明

目次setState は同期ですか、それとも非同期ですか?カスタム合成イベントと React フック...

ウェブサイトを黒、白、グレーにする4つのコードの詳細な説明

2008年5月12日に四川省汶川市で発生した地震により、多くの命が失われ、遺憾なことと存じます。国務...

Dockerを使用してPythonランタイム環境の基本イメージを作成する方法

1. 準備1.1 Pythonインストールパッケージをダウンロードします(注:Pythonバージョン...

仮想マシンの複製に関するVirtual Boxチュートリアル図

VMに慣れた後、BOXに切り替えるのは少し異なります。たとえば、コピーネットワークカードを2枚使って...

ネイティブJSで様々なモーションの複合モーションを実現

この記事では、ネイティブ JS で実装された複合モーションを紹介します。複合モーションとは、異なる属...

Webデザイン: タイトルが完全に表示できない場合

<br />今日、新しくなった ChinaUI.com の Web サイトを見たのですが...

Macでのファイル権限の表示と設定の詳細な説明

序文Mac システムのターミナルでファイルの権限を変更するには、Linux の chmod コマンド...

MySQL マスタースレーブ同期メカニズムと同期遅延問題追跡プロセス

序文DBA として、仕事中に MySQL マスターとスレーブの同期遅延の問題に遭遇することがよくあり...

Nginxリバースプロキシ設定でプレフィックスが削除される

nginx をリバース プロキシとして使用する場合、リクエストをそのまま次のサービスに転送するだけで...

HTML のセルパディングとセルスペース属性を図で説明します

セル - 表の内容 セルの余白 (表の余白) (cellpadding) - セルの外側の距離を表し...

MySQL Shellの紹介とインストール

目次01 レプリ​​カセットアーキテクチャ02 MySQL Shellの紹介とインストール03 My...

CSSを使用して複数の画像を中央に水平に表示する方法

まず実装手順について説明します。最終結果 2. コードの実装HTML部分 <div class...

モバイル ブラウザのビューポート パラメータ (Web フロントエンド デザイン)

モバイル ブラウザは、Web ページを仮想の「ウィンドウ」(ビューポート) に配置します。このウィン...