コアポイント
- jQueryプラグインを必要とせずにアニメーションのスティッキーナビゲーションメニューを作成します。メニューは、スクロールするときに視界からスライドして、スクロールするときに半透明の効果で視界に戻ってスライドするように設計されています。
- このプロセスには、基本的なHTML構造のセットアップ、メイン要素にスタイルを適用してからメニューをアニメーション化することが含まれます。アニメーションは、イベントハンドラーをスクロールイベントに添付し、CSS変換を使用してスクロール方向に応じてメニューの位置と外観を調整することによりトリガーされます。
- このカスタマイズソリューションは、設計の柔軟性を高め、特定のニーズに応じて簡単にカスタマイズできるようになります。最終結果は、ユーザーエクスペリエンスを向上させる動的なインタラクティブナビゲーションメニューです。
Webナビゲーションメニューの設計では、メニューの場所、スタイル、レスポンシブデザインなど、多くの要因を考慮する必要があります。また、いくつかのアニメーション効果を追加することもできます(もちろん、ちょうどいいです)。この時点で、jQueryプラグインを使用してほとんどの作業を行う傾向があります。しかし、実際には必要ありません!独自のソリューションを簡単に作成するには、数行のコードしかかかりません。
この記事では、純粋なJavaScript、CSS、およびHTMLを使用して、アニメーションのスティッキーナビゲーションメニューを作成する方法を示します。最終製品は、ページを下にスクロールするときにスワイプし、スクロールするときにスライドしてビューに戻ります(スタイリッシュな半透明の効果があります)。このテクノロジーは、MediumやHackerの正午などの有名なWebサイトで使用されています。読んだ後、このテクノロジーをデザインで使用して、良い結果を達成することを望んでいます。緊急の読者が参照するための記事の最後にデモがあります。
スティッキーナビゲーションメニュー:基本的なHTML構造
以下は、使用する基本的なHTMLコードフレームワークです。ここには何もエキサイティングなことはありません。
<div class="container"> <div class="banner-wrapper"> <div class="banner"> <div class="top"> </div> <div class="nav"> </div> </div> </div> <div class="content"> </div> </div>
いくつかのスタイルを適用します
メイン要素にいくつかのスタイルを追加しましょう。メインコンテナ
固有のブラウザスタイルを削除し、コンテナの幅を100%に設定する必要があります。
*{ box-sizing:border-box; padding: 0; margin: 0; } .container{ width: 100%; }バナーコンテナ
これは、ナビゲーションメニューのラッパーです。ページを垂直にスクロールするときに、ナビゲーションメニューを非表示または表示するのは常に粘着性があり、スライドします。 Z-Index値を提供して、コンテンツの上に表示されることを確認します。
.banner-wrapper { z-index: 4; transition: all 300ms ease-in-out; position: fixed; width: 100%; }バナーセクション
これにはナビゲーションメニューが含まれています。ページが上下にスクロールすると、位置と背景色の変更はCSSトランジションプロパティによってアニメーション化されます。
.banner { height: 77px; display: flex; flex-direction: column; justify-content: space-around; background: rgba(162, 197, 35, 1); transition: all 300ms ease-in-out; }コンテンツパート
このセクションには、背景画像とテキストが含まれています。この記事の後半で、このページに視差効果を追加します。
.content { background: url(https://unsplash.it/1400/1400?image=699) center no-repeat; background-size: cover; padding-top: 100%; }メニューアニメーション
最初に、ユーザーがスクロールするときにメニューを表示して非表示にできるように、イベントハンドラーをスクロールイベントに添付する必要があります。また、同じページで実行されている他のコードとの競合を避けるために、すべてを1つのIIFEに入れます。
<div class="container"> <div class="banner-wrapper"> <div class="banner"> <div class="top"> </div> <div class="nav"> </div> </div> </div> <div class="content"> </div> </div>
いくつかの初期値を設定
RefOffset変数を使用して、ユーザーが下にスクロールする距離を示します。ページが読み込まれると、0に初期化されます。 BannerHeight変数を使用してメニューの高さを保存し、.banner-wrapper
および.banner
DOM要素への参照も必要です。
*{ box-sizing:border-box; padding: 0; margin: 0; } .container{ width: 100%; }
スクロール方向を作成
次に、メニューをそれに応じて表示または非表示にできるように、スクロール方向を決定する必要があります。
NewOffsetという変数から始めます。ページが読み込まれると、これはwindow.scrollY
の値に設定されます - ドキュメントが現在垂直にスクロールしているピクセルの数(最初は0)。ユーザーがスクロールすると、NewOffsetはそれに応じて増加または減少します。 Bannerheightに保存されている値よりも大きい場合、メニューが視界からスクロールされていることがわかります。
.banner-wrapper { z-index: 4; transition: all 300ms ease-in-out; position: fixed; width: 100%; }
下にスクロールすると、NewOffsetがRefOffsetよりも大きくなり、ナビゲーションメニューがスライドして消えます。スクロールアップすると、NewOffsetがRefOffsetよりも小さくなり、ナビゲーションメニューは半透明の効果で視界に戻って戻ってきます。この比較の後、ユーザーがスクロールする距離を追跡するために、newOffsetの値で再オフェットを更新する必要があります。
.banner { height: 77px; display: flex; flex-direction: column; justify-content: space-around; background: rgba(162, 197, 35, 1); transition: all 300ms ease-in-out; }
メニューアニメーション
最後に、メニューを表示して非表示にするためのアニメーションを追加しましょう。次のCSSを使用してこれを達成できます。
また、ページの上部に到達したら、メニューから半透明の効果が削除されることを確認する必要があります。.content { background: url(https://unsplash.it/1400/1400?image=699) center no-repeat; background-size: cover; padding-top: 100%; }
ご覧のとおり、それに応じてさまざまなCSSクラスを削除/適用しています。
(() => { 'use strict'; const handler = () => { //DOM操作代码在此处 }; window.addEventListener('scroll', handler, false); })();demo
これは、作業メニューのデモです。 (CodePenデモリンクは、外部のWebサイトにアクセスできないため、ここに挿入する必要があります。実際のリンクは提供できません)
結論この記事では、アニメーションナビゲーションメニューを設計するために純粋なJavaScript(jQuery不要)を使用して数行のコードを作成する方法について説明します。スクロールすると、メニューがスクロールすると、メニューがスライドして透明な効果で表示されます。これは、垂直スクロール方向を監視し、必要に応じてCSS変換をDOM要素に適用することによって行われます。このカスタムソリューションにより、ニーズと仕様に応じて、簡単かつ柔軟に設計できる自由が高まります。
JavaScriptスキルを向上させたいですか? JavaScriptとJavaScript:Nextで始まるコースをご覧ください。
この記事は、Vildan Softicによって査読されました。 SetePointのすべてのピアレビューアーズに感謝します。
(JavaScriptアニメーションのSticky NavigationメニューのFAQセクションをここに含める必要があり、コンテンツは入力テキストと一致しています。スペースの制限のため、ここで省略されています。
以上がVanilla JavaScript:アニメーションのスティッキーナビゲーションメニューの作成の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

JavaScriptフレームワークのパワーは、開発を簡素化し、ユーザーエクスペリエンスとアプリケーションのパフォーマンスを向上させることにあります。フレームワークを選択するときは、次のことを検討してください。1。プロジェクトのサイズと複雑さ、2。チームエクスペリエンス、3。エコシステムとコミュニティサポート。

はじめに私はあなたがそれを奇妙に思うかもしれないことを知っています、JavaScript、C、およびブラウザは正確に何をしなければなりませんか?彼らは無関係であるように見えますが、実際、彼らは現代のウェブ開発において非常に重要な役割を果たしています。今日は、これら3つの間の密接なつながりについて説明します。この記事を通して、JavaScriptがブラウザでどのように実行されるか、ブラウザエンジンでのCの役割、およびそれらが協力してWebページのレンダリングと相互作用を駆動する方法を学びます。私たちは皆、JavaScriptとブラウザの関係を知っています。 JavaScriptは、フロントエンド開発のコア言語です。ブラウザで直接実行され、Webページが鮮明で興味深いものになります。なぜJavascrを疑問に思ったことがありますか

node.jsは、主にストリームのおかげで、効率的なI/Oで優れています。 ストリームはデータを段階的に処理し、メモリの過負荷を回避します。大きなファイル、ネットワークタスク、リアルタイムアプリケーションの場合。ストリームとTypeScriptのタイプの安全性を組み合わせることで、パワーが作成されます

PythonとJavaScriptのパフォーマンスと効率の違いは、主に以下に反映されています。1)解釈された言語として、Pythonはゆっくりと実行されますが、開発効率が高く、迅速なプロトタイプ開発に適しています。 2)JavaScriptはブラウザ内の単一のスレッドに限定されていますが、マルチスレッドおよび非同期I/Oを使用してnode.jsのパフォーマンスを改善でき、両方とも実際のプロジェクトで利点があります。

JavaScriptは1995年に発信され、Brandon Ikeによって作成され、言語をCに実現しました。 2。JavaScriptのメモリ管理とパフォーマンスの最適化は、C言語に依存しています。 3. C言語のクロスプラットフォーム機能は、さまざまなオペレーティングシステムでJavaScriptを効率的に実行するのに役立ちます。

JavaScriptはブラウザとnode.js環境で実行され、JavaScriptエンジンに依存してコードを解析および実行します。 1)解析段階で抽象的構文ツリー(AST)を生成します。 2)ASTをコンパイル段階のバイトコードまたはマシンコードに変換します。 3)実行段階でコンパイルされたコードを実行します。

PythonとJavaScriptの将来の傾向には、1。Pythonが科学コンピューティングの分野での位置を統合し、AI、2。JavaScriptはWebテクノロジーの開発を促進します。どちらもそれぞれのフィールドでアプリケーションシナリオを拡大し続け、パフォーマンスをより多くのブレークスルーを行います。

開発環境におけるPythonとJavaScriptの両方の選択が重要です。 1)Pythonの開発環境には、Pycharm、Jupyternotebook、Anacondaが含まれます。これらは、データサイエンスと迅速なプロトタイピングに適しています。 2)JavaScriptの開発環境には、フロントエンドおよびバックエンド開発に適したnode.js、vscode、およびwebpackが含まれます。プロジェクトのニーズに応じて適切なツールを選択すると、開発効率とプロジェクトの成功率が向上する可能性があります。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

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

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

ホットトピック









