これは、ブラウザーでの履歴スタック管理の関連コンテンツについて説明する基本的な記事です。これを書いた理由は、最近、PushState を使用して SPA を実装するときにどのような問題が発生するかを調べたかったためです。PushState は最終的にブラウザー履歴スタックのコンテンツに影響を与えるため、ブラウザーがそれをどのように管理するかを検討しました。履歴スタック。というのも、調べていくうちに、今まで気づかなかった重要なポイントがいくつか見つかったので、記録しておきました。
デモのアドレス: http://liuyunzhuge.github.io/blog/history/demo1.html
このデモは、この記事で後述する関連テストに使用されます。興味がある場合は、新しい問題をテストするたびに、既に開いている問題から開くのではなく、新しいタブでこのデモを開くことをお勧めします。 Web ページのタブを開きます。Web ページのタブが開かれているため、その履歴スタックには以前にアクセスした Web ページの記録がすでに含まれているため、テストする問題の結果に影響します。
ブラウザは、同じウィンドウ (タブ) 内で訪問した Web ページを記録します。次のいずれかの方法で Web ページを変更しても、ブラウザは変更された Web ページを記録し、ブラウザの転送や転送を通じて使用できるようにします。 [戻る] ボタンを使用すると、訪問した Web ページにすぐに切り替えることができます:
1) アドレス バーに Web ページのアドレスを直接入力します。
2) Web ページ内のハイパーリンクをクリックすると、他の Web ページにジャンプできません。新しいウィンドウで開くリンクであること。
3) スクリプトを通じて location.href を変更することで他の Web ページにジャンプする。ただし、フォームを送信して他の Web ページにジャンプすることはできない。窓。
つまり、Web ページが同じウィンドウ内でジャンプしている限り、ブラウザはそれを記録します。更新を除いて、履歴オブジェクトの長さ属性は、現在のウィンドウに保存されている履歴レコードの総数を表示できます。この属性は、Web ページが変更された場合にのみ変更されます。 Web ページの更新中 このプロパティは変更されません。
操作テスト 1: 前のデモのアドレスをコピーし、Chrome ブラウザで次の手順に従ってください:
新しいタブを開き、demo2.html をクリックし、demo3.html をクリックします。ブラウザは、以下の図と同様の方法で上記のアクセス記録を保存します:
1) forward 関数/go(1)/forward はポインタを 1 位置だけ上に移動します。
2) reverse 関数/go(-1)/forward は、ポインターを 1 位置下に移動するだけです。
3) go(n) はポインタを n 位置上に移動し、go(-n) はポインタを n 位置下に移動します。ブラウザは履歴スタックで Web ページを見つけ、移動されたポインターの位置に基づいて表示します。
の結果をテストするために
操作を実行し続ける場合は、引き続き次の操作を実行します。動作テスト2:
ブラウザの戻るボタンを7回クリックします。この時、ブラウザの履歴スタックの保存状況は以下の状態になります:
history.go(n)、history.go(-n)は任意の位置にポインタを移動できますが、移動する位置が履歴スタックの位置範囲を超える場合、ポインタは移動しません。そのため、動作テスト 2 の結果では、history.go(-100) とhistory.go(100) の呼び出しは機能しません。
履歴スタックの内容を変更する状況が他に 2 つあります。
動作テスト 3: 動作テスト 2 の結果に従い、進むボタンを 3 回クリックすると、ブラウザの履歴スタックは次の状態になります:
この時点では、操作テスト 2 も操作テスト 3 も履歴スタックの内容を変更していないため、正しければ、ページ上の履歴統計は 8 のままであるはずです。
操作テスト 4: 次に、次の 2 つの手順を実行します: [demo2.html] をクリックし、[demo3.html] をクリックします。この時点で、ページ上の履歴統計は次のようになります:
ブラウザの履歴レコード管理におけるもう 1 つの重要なポイントは、保存される履歴スタックの総数に制限があることです。Chrome と Firefox はどちらも 50 です。履歴スタックのストレージ量がこの制限を超えると、履歴レコードのストレージはローリング方式で格納されます。つまり、新しいレコードがスタックの一番上にプッシュされ、一番下のレコードが一番下から削除されます。スタックの。デモページ上でdemo1、demo2、demo3、demo4を切り替えてクリックし続けると、一定回数に達するとページに印刷されている統計情報が変化しなくなり、履歴の上限に達したことになります。ただし、IE11 では 100 を超えるまでクリックしたところ、まだ変化していることがわかり、IE の制限がより高いかどうかを示しています。 。
この記事にはブラウザの履歴管理に関する内容が含まれているため、分析に不備がある可能性があります。ご批判や修正をお待ちしております。上記の内容が、歴史と州への理解を深める必要がある友人たちに役立つことを願っています:)

webdevelopmentReliesOnhtml、css、andjavascript:1)htmlStructuresContent、2)cssStylesit、および3)Javascriptaddsinteractivity、形成、

HTMLの役割は、タグと属性を使用してWebページの構造とコンテンツを定義することです。 1。HTMLは、読みやすく理解しやすいようなタグを介してコンテンツを整理します。 2。アクセシビリティとSEOを強化するには、セマンティックタグなどを使用します。 3. HTMLコードの最適化により、Webページの読み込み速度とユーザーエクスペリエンスが向上する可能性があります。

HTML、CSS、およびJavaScriptは、Web開発の3つの柱です。 1。HTMLは、Webページ構造を定義し、などなどのタグを使用します。2。CSSは、色、フォントサイズなどのセレクターと属性を使用してWebページスタイルを制御します。

HTMLはWeb構造を定義し、CSSはスタイルとレイアウトを担当し、JavaScriptは動的な相互作用を提供します。 3人はWeb開発で職務を遂行し、共同でカラフルなWebサイトを構築します。

HTMLは、簡単に学習しやすく、結果をすばやく見ることができるため、初心者に適しています。 1)HTMLの学習曲線はスムーズで簡単に開始できます。 2)基本タグをマスターして、Webページの作成を開始します。 3)柔軟性が高く、CSSおよびJavaScriptと組み合わせて使用できます。 4)豊富な学習リソースと最新のツールは、学習プロセスをサポートしています。

Anexampleapalofastartingtaginhtmlis、それはaperginsaparagraph.startingtagsaresentionentientiontheyinitiateelements、definetheirtypes、およびarecrucialforurturingwebpagesandcontingthomedomを構築します。

メニューで点線のラインセグメンテーション効果を設計する方法は?メニューを設計するときは、通常、皿の名前と価格の間に左右に合わせることは難しくありませんが、真ん中の点線またはポイントはどうですか...


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。
