ホームページ >ウェブフロントエンド >jsチュートリアル >JSフロントエンドキャッシュの実装方法とCookieの特徴の紹介
フロントエンド ブラウザでは、最初のリクエスト中に一部のデータ (データ ディクショナリ内のデータなど) を取得して js オブジェクトに保存できるため、必要なときに毎回サーバーをリクエストする必要はありません。未来。ドロップダウン ボックスにデータを入力するためにデータ ディクショナリを頻繁に使用するページの場合、このアプローチによりサーバーへのアクセスが大幅に削減されます。この方法は、iframe を使用したフレームで特にうまく機能します。
この記事では主に JS でフロントエンド キャッシュを実装する方法を詳しく紹介しますので、興味のある方は参考にしていただければ幸いです。
具体的な実装アイデアと方法:
cache.js ファイルを作成します:
1. フロントエンド ページ、フロントエンド キャッシュから一度に取得する必要があるデータを定義し、これらを保存するオブジェクトを定義します。 data:
/**
* 定义需要在用户登录的时候获取到本地的数据字典类别
*/
var clsCodes = {clsCodes :
[BOOL,
STATUS,
USER_TYPE,
REPORT_STATUS
]
};
/**
* 获取数据字典到本地
*/
var dicts;2 (フロントエンド ページ) は、バックエンド インターフェイスを呼び出してデータを取得し、それをローカル キャッシュ オブジェクト (dict) に保存する関数を定義します。
function getDicts() {
$.post(getContextPath() + /api/sys/getDictList,
clsCodes,
function(resultBean, status, xhRequest) {
if (resultBean.data != undefined) {
dicts = resultBean.data;
}
},
'json');
}このメソッドを呼び出してデータを一度に取得し、メインページのロード時にキャッシュします。このようにして、将来同じデータが必要になった場合、ローカル オブジェクトの辞書から直接取得できます。
バックエンド コントローラー:
3. データを取得してフロントエンドに返すフロントエンド リクエストに従ってデータベースにクエリ (または、次の例のようにサーバー キャッシュにクエリ) するインターフェイスを定義します。
/**
* 根据多个分类编号获取多个字典集合
* @param clsCodes
* @return {{clsCode : {code1:name1,code2:name2...}}, ...}
*/
@SuppressWarnings({ unchecked, rawtypes })
@ResponseBody
@RequestMapping(getDictList)
public ResultBean getDictList(@RequestParam(value = clsCodes[], required = true) String[] clsCodes) {
ResultBean rb = new ResultBean();
Map<string, string="">> dictCache = (Map<string, string="">>) CacheManager.getInstance().get(CacheConstants.DICT);
Map dictMap = new LinkedHashMap<>(); //使用LinkedHashMap保证顺序
if(dictCache != null){
for(String clsCode: clsCodes){
dictMap.put(clsCode, dictCache.get(clsCode));
}
}else{
rb.setMessage(缓存中拿不到字典信息!);
rb.setSuccess(false);
}
rb.setData(dictMap);
return rb;
}</string,></string,>1) Cookieのサイズは4KBに制限されており、大きなファイルやメールなどの大きなデータを受け入れることができません。
2) Cookie を含むリクエストがある限り、Cookie はサーバーとブラウザの間で送受信されます (これが、ローカル ファイルが Cookie をテストできない理由の説明になります)。さらに、Cookie データは常に同じオリジンからの http リクエストに含まれます (必要でない場合でも)。これは、Cookie が大きくなりすぎない重要な理由でもあります。オーソドックスな Cookie の配布は、HTTP プロトコルを拡張することによって実現され、サーバーは HTTP 応答ヘッダーに特別な命令行を追加し、その命令に従って対応する Cookie を生成するようブラウザに指示します。
3) ユーザーがサーバーデータをリクエストするたびに、そのリクエストとともに Cookie がサーバーに送信されます。PHP などのサーバースクリプト言語は、Cookie によって送信されたデータを処理でき、非常に便利であると言えます。もちろんフロントエンドでもCookieを生成することはできますが、Cookieをjsで操作するのはブラウザがdocument.cookieなどのオブジェクトを提供するだけで、Cookieの割り当てや取得が面倒です。 PHP では、setcookie() を通じて Cookie を設定し、スーパーグローバル配列 $_COOKIE を通じて Cookie を取得できます。
Cookie の内容には主に、名前、値、有効期限、パス、ドメインが含まれます。パスとドメインを合わせて Cookie のスコープを形成します。有効期限が設定されていない場合、この Cookie の有効期間はブラウザ セッション中にあり、ブラウザ ウィンドウを閉じると Cookie は消えます。ブラウザーのセッション中に保持されるこのタイプの Cookie は、セッション Cookie と呼ばれます。セッション Cookie は通常、ハードディスクではなくメモリに保存されます。もちろん、この動作は仕様で指定されていません。有効期限が設定されている場合、ブラウザは Cookie をハードディスクに保存します。ブラウザを閉じて再度開いても、設定された有効期限が経過するまでこれらの Cookie は有効です。ハード ドライブに保存された Cookie は、2 つの IE ウィンドウなど、異なるブラウザ プロセス間で共有できます。ブラウザーが異なれば、メモリに保存された Cookie を処理する方法も異なります。
関連する推奨事項:
JS を使用してフロントエンド キャッシュを実装する以上がJSフロントエンドキャッシュの実装方法とCookieの特徴の紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。