CSSで気の利いたNetflixアニメーションを再作成する方法
Netflixブラウジングページの設計は、長年にわたって高度な一貫性を維持しています。主なコンポーネントの1つはプレビュースライダーです。これにより、ユーザーはコンテンツをスクロールしてプロジェクト上でホバリングしてプレビューを表示できます。
このUIのユニークな機能の1つは、ホバー動作です。ショープレビューがホバーで拡張されると、その隣のカードが外側に押して、オーバーラップを避けます。
このような:
CSSでこの効果を達成できます! JavaScriptは不要、依存関係は必要ありません。純粋なCSSを実行できます。しかし、コードを入力する前に、私たちが達成したいことを明確にしましょう。
- ホバリングカードは、アスペクト比を維持しながら拡張する必要があります。
- 1枚のカードがhoverくると、他のカードはサイズを変更せず、互いに重複しないように外側に移動する必要があります。
- すべてのカードは、互いに垂直に集中する必要があります。
いいですね?次に、コードセクションに行きましょう。
HTMLおよび弾性要素
Netflixのビデオプレビューを表すために、画像の行を設定しましょう。これには次のものが含まれます。
- a
.containerparent
要素.item
含む - 各
.item
要素には、アンカータグでラップされた画像が含まれています -
.container
をフレックスコンテナに変換して、アイテムを連続して調整します -
.item
クラスのフレックス動作を設定して、列の等しいスペースを占めるように設定します
ホバリング中にアイテムを拡張します
次のステップは、プロジェクトをホバーで展開することです。これをアニメーション要素の幅で行うことができますが、これはドキュメントの流れに影響を与え、ホバリングアイテムの兄弟要素が縮小する可能性があります。
ホバープロジェクトの兄弟要素を絞ることを避けるために、 transform
プロパティ(特にscale()
関数)をアニメーション化します。これは、幅ほどドキュメントフローに影響しません。
兄弟の要素を外側に移動します
ホバープロジェクトをホバープロジェクトから遠ざけることは、プロセスの最も難しい部分です。使用できるCSS機能の1つは、ユニバーサル兄弟の組み合わせです。これにより、ホバープロジェクトの背後にあるすべての兄弟プロジェクトを選択できます。
transform
PropertyのtranslateX()
関数に目を向けて、要素を移動します。同様に、 transform
のアニメーションは、マージンやパディングなど、ドキュメントの流れに影響を与える他のプロパティよりもはるかに優れています。
ホバーで150%をズームインするようにアイテムを設定したため、パンは25%に設定する必要があります。これは、ホバープロジェクトが占める余分なスペースの半分です。
<code>.item:hover ~ .item { transform: translateX(25%); }</code>
これにより、要素を右に移動することができますが、要素を左にどのように供給しますか?ユニバーサル兄弟コンビナーは、特定のセレクターの背後にある兄弟要素にのみ適しているため、別のアプローチが必要です。
1つの方法は、親コンテナ自体に追加のホバールールを追加することです。これが計画です:
- 親コンテナをホバリングするときは、親コンテナ内のすべてのアイテムを左に移動します。
- ユニバーサルブラザーコンビネーターを使用して、ホバーアイテムの背後にあるアイテムを右側に移動します。
- 操作は、ホバーアイテムが他のアイテムのようにパンされないようにするために非常に具体的です。
ドキュメントが左から右へのライティングモードを使用していると仮定しましょう。この効果を右から左にコンテキストで使用する場合は、ホバーアウター容器内のすべてのアイテムを右に移動し、ユニバーサル兄弟コンバイナーを使用して選択したすべてのアイテムを左に移動する必要があります。
デモ時間!
注意すべきことの1つは、最終バージョンが次の:focus
と:focus-within
キーボードナビゲーションをサポートすることです。 Netflixの例はそれを使用していませんが、これはアクセシビリティへの良い追加だと思います。
それでおしまい!はい、CSS Hoverルールの代わりにJavaScriptイベントリスナーを使用できます。これは、メンテナンスと読みやすさをより助長する場合があります。しかし、CSSがどれだけ私たちを連れて行くことができるかを見るのも楽しいことです!
以上がCSSで気の利いたNetflixアニメーションを再作成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











プロジェクトにカウントダウンタイマーが必要だったことはありますか?そのようなことのために、プラグインに手を伸ばすのは自然なことかもしれませんが、実際にはもっとたくさんあります

新しいプロジェクトの開始時に、SASSコンピレーションは瞬く間に起こります。これは、特にbrowsersyncとペアになっている場合は素晴らしい気分です。

Lea verou&#039; conic-gradient()Polyfillの機能のリストに目を向けたことの1つが最後の項目でした。

インラインテンプレートディレクティブにより、既存のWordPressマークアップに対する進行性の強化として、リッチVUEコンポーネントを構築できます。

新しいプロジェクトを開始するたびに、3つのタイプ、または必要に応じてカテゴリを検討しているコードを整理します。そして、これらのタイプは適用できると思います

PHPテンプレートは、多くの場合、サブパーコードを促進するために悪いラップを取得しますが、そうである必要はありません。 PHPプロジェクトが基本を実施する方法を見てみましょう
