検索
ホームページウェブフロントエンドjsチュートリアルページをリロードせずにJavaScriptで履歴レコードを作成する方法(コード)

この記事の内容は、JavaScript がページをリロードせずに履歴レコード (コード) を作成する方法についてです。必要な方は参考にしていただければ幸いです。

背景

最近仕事中に、複数ページのアプリケーションで同じデータ ソースを複数のページで共有する必要があるという要件に遭遇しました。ページはページ データを更新せず、履歴レコードの逆方向機能を実現できます。これは、初期段階では複数のページを 1 ページに実現する効果のみが考慮され、履歴スタックでの処理が考慮されていなかったためです。ページが一度に入り口から押し出される。いくつかの解決策を以下にまとめます。

hash

URL 内の # は、Web ページ上の場所を表す場所識別子と呼ばれます。私たちが最初に a タグに触れたとき、私たちの多くは、主にアンカーポイントジャンプを操作したことがあります。 href ジャンプ先の場所の ID 値を設定します。このプロセス中、ページは更新されませんが、window.location.hash を使用して現在のページのハッシュ値を取得できます。同時に、それを通じて新しいハッシュ値を書き込み、hashchange イベントをリッスンしてハッシュ値が変更されたかどうかを検出することもできます。ポップアップ マスク ページをクリックすると、location.hash の値を手動で変更できるため、window.history.back() をクリックすると、履歴をロールバックできます。例

# コードは次のとおりです。

nbsp;html>


    <meta>
    <title>Title</title>
    <style>
        body{
            background: #ccc;
        }
        .colorBlock {
            border: 10px solid #fff;
            height: 40vh;
            width: 40vh;
            margin: 20vh auto 10vh;
            color: #ffffff;
            font-size: 40px;
            line-height: 40vh;
            text-align: center;
        }
        .colorBlue{
            border: 10px solid #fff;
            height: 40vh;
            width: 40vh;
            margin: 20vh auto 10vh;
            color: #ffffff;
            font-size: 40px;
            line-height: 40vh;
            text-align: center;
            background: cornflowerblue;
        }
        .colorgray{
            border: 10px solid #fff;
            height: 40vh;
            width: 40vh;
            margin: 20vh auto 10vh;
            color: #ffffff;
            font-size: 40px;
            line-height: 40vh;
            text-align: center;
            background: lightcoral;
        }
        .colorgreen{
            border: 10px solid #fff;
            height: 40vh;
            width: 40vh;
            margin: 20vh auto 10vh;
            color: #ffffff;
            font-size: 40px;
            line-height: 40vh;
            text-align: center;
            background: greenyellow;
        }
        .btnBlock{
            text-align: center;
        }
        .btn{
            border: 5px solid #ffffff;
            font-size: 24px;
            line-height: 50px;
            width: 40vh;
        }
    </style>


<div>
    加载中....
</div>
<div>
    <button>change-url</button>
</div>
<script>
    (
        function () {
            var a=0;
            setInterval(function () {
                a++;
                document.getElementById("content").innerText=a;
            },1000)
        }
    )()
    window.addEventListener("hashchange",function (e) {
        var now=location.hash && location.hash.substring(1);
        switch (now){
            case "blue":
                document.getElementById("content").setAttribute("class","colorBlue");
                break;
            case "gray":
                document.getElementById("content").setAttribute("class","colorgray");
                break;
            case "green":
                document.getElementById("content").setAttribute("class","colorgreen");
                break;
        }

    },false);
    document.getElementsByClassName("btn")[0].addEventListener("click",function () {
        var now=location.hash && location.hash.substring(1);
        if(now=="blue"){
            location.hash="gray"
            document.getElementById("content").setAttribute("class","colorgray");
        }else if(now=="gray"){
            location.hash="green"
            document.getElementById("content").setAttribute("class","colorgreen");
        }else if(now=="green"){
            location.hash="blue"
            document.getElementById("content").setAttribute("class","colorBlue");
        }
    },false);
</script>

ブラウザでページを開き、次のように #blue をルートに追加します。

#次のページが表示されます。初期状態では、ページの表示が読み込まれています。その後、タイマーが更新をトリガーし、増加する数値を表示します。コンソールで対応するhistory.lengthを出力できます。その値は2です: ページをリロードせずにJavaScriptで履歴レコードを作成する方法(コード)

ページをリロードせずにJavaScriptで履歴レコードを作成する方法(コード)

##Continue 次に、URL 変更ボタンをクリックしてハッシュ値を変更します。対応するパスが変更され、#blue が #g'ra になり、それに応じて背景色も変更されていることがわかります。増加する数値の時間は更新されていません。つまり、ページが更新と再読み込みのプロセスを経ていないことを意味します。 ページをリロードせずにJavaScriptで履歴レコードを作成する方法(コード)

ページをリロードせずにJavaScriptで履歴レコードを作成する方法(コード)

コンソールに window.history.length を再入力して確認します。値は 3 に変更されました。ブラウザの戻る矢印をクリックすると、ページの背景が前の青色の背景に変わります。

ページをリロードせずにJavaScriptで履歴レコードを作成する方法(コード)

#history.pushStateページをリロードせずにJavaScriptで履歴レコードを作成する方法(コード)上記の方法に加えて、html5 の新しいhistory.pushState を使用しても同じ効果を実現できます。 History.replaceState とhistory.replaceState はどちらも HTML5 の新しい API です。どちらもページを更新せずにステータス バーの URL を変更できます。ただし、この 2 つの違いは、replaceState が現在のアドレスを指定された URL に置き換えるのに対し、pushState は URL を作成することです。新しい歴史的記録。 window.onpopstate イベントは、history.back() およびhistory.forward() の実行後にトリガーされます。

API

history.pushState(state,title,url)
state: オブジェクト。現在の状態を表すデータを保存できます。ブラウザが順方向または逆方向に実行されると、onpopState イベントがトリガーされ、statez の属性値はオブジェクトにできないことに注意してください。 url は置き換えられるアドレスです。puhState の場合、履歴レコードが追加されます。

#Example

上記の例を使用してテストすることもできます。監視する必要があるのは、popstate イベントであり、新しい履歴レコードを作成し、現在の情報をhistory.state に保存します。上記で紹介した方法はページが飛ばないことを前提としており、URLを変更して新たな履歴を追加したり、ブラウザのデフォルトテキストで前後の操作を行うことも可能ですが、注意が必要です。 2 つは、変更をトリガーする異なる応答イベントを監視し、URL を変更する方法も異なります。


以上がページをリロードせずにJavaScriptで履歴レコードを作成する方法(コード)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事はsegmentfaultで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
JavaScriptとWeb:コア機能とユースケースJavaScriptとWeb:コア機能とユースケースApr 18, 2025 am 12:19 AM

Web開発におけるJavaScriptの主な用途には、クライアントの相互作用、フォーム検証、非同期通信が含まれます。 1)DOM操作による動的なコンテンツの更新とユーザーインタラクション。 2)ユーザーエクスペリエンスを改善するためにデータを提出する前に、クライアントの検証が実行されます。 3)サーバーとのリフレッシュレス通信は、AJAXテクノロジーを通じて達成されます。

JavaScriptエンジンの理解:実装の詳細JavaScriptエンジンの理解:実装の詳細Apr 17, 2025 am 12:05 AM

JavaScriptエンジンが内部的にどのように機能するかを理解することは、開発者にとってより効率的なコードの作成とパフォーマンスのボトルネックと最適化戦略の理解に役立つためです。 1)エンジンのワークフローには、3つの段階が含まれます。解析、コンパイル、実行。 2)実行プロセス中、エンジンはインラインキャッシュや非表示クラスなどの動的最適化を実行します。 3)ベストプラクティスには、グローバル変数の避け、ループの最適化、constとletsの使用、閉鎖の過度の使用の回避が含まれます。

Python vs. JavaScript:学習曲線と使いやすさPython vs. JavaScript:学習曲線と使いやすさApr 16, 2025 am 12:12 AM

Pythonは、スムーズな学習曲線と簡潔な構文を備えた初心者により適しています。 JavaScriptは、急な学習曲線と柔軟な構文を備えたフロントエンド開発に適しています。 1。Python構文は直感的で、データサイエンスやバックエンド開発に適しています。 2。JavaScriptは柔軟で、フロントエンドおよびサーバー側のプログラミングで広く使用されています。

Python vs. JavaScript:コミュニティ、ライブラリ、リソースPython vs. JavaScript:コミュニティ、ライブラリ、リソースApr 15, 2025 am 12:16 AM

PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。

C/CからJavaScriptへ:すべてがどのように機能するかC/CからJavaScriptへ:すべてがどのように機能するかApr 14, 2025 am 12:05 AM

C/CからJavaScriptへのシフトには、動的なタイピング、ゴミ収集、非同期プログラミングへの適応が必要です。 1)C/Cは、手動メモリ管理を必要とする静的に型付けられた言語であり、JavaScriptは動的に型付けされ、ごみ収集が自動的に処理されます。 2)C/Cはマシンコードにコンパイルする必要がありますが、JavaScriptは解釈言語です。 3)JavaScriptは、閉鎖、プロトタイプチェーン、約束などの概念を導入します。これにより、柔軟性と非同期プログラミング機能が向上します。

JavaScriptエンジン:実装の比較JavaScriptエンジン:実装の比較Apr 13, 2025 am 12:05 AM

さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

ブラウザを超えて:現実世界のJavaScriptブラウザを超えて:現実世界のJavaScriptApr 12, 2025 am 12:06 AM

現実世界におけるJavaScriptのアプリケーションには、サーバー側のプログラミング、モバイルアプリケーション開発、モノのインターネット制御が含まれます。 2。モバイルアプリケーションの開発は、ReactNativeを通じて実行され、クロスプラットフォームの展開をサポートします。 3.ハードウェアの相互作用に適したJohnny-Fiveライブラリを介したIoTデバイス制御に使用されます。

next.jsを使用してマルチテナントSaaSアプリケーションを構築する(バックエンド統合)next.jsを使用してマルチテナントSaaSアプリケーションを構築する(バックエンド統合)Apr 11, 2025 am 08:23 AM

私はあなたの日常的な技術ツールを使用して機能的なマルチテナントSaaSアプリケーション(EDTECHアプリ)を作成しましたが、あなたは同じことをすることができます。 まず、マルチテナントSaaSアプリケーションとは何ですか? マルチテナントSaaSアプリケーションを使用すると、Singの複数の顧客にサービスを提供できます

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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