JS實現(xiàn)前端緩存的方法
在前端瀏覽器中,有些數(shù)據(jù)(比如數(shù)據(jù)字典中的數(shù)據(jù)),可以在第一次請求的時候全部拿過來保存在js對象中,以后需要的時候就不用每次都去請求服務器了。對于那些大量使用數(shù)據(jù)字典來填充下拉框的頁面,這種方法可以極大地減少對服務器的訪問。這種方法特別適用于使用iframe的框架。
具體實現(xiàn)思路和方法:
創(chuàng)建一個cache.js文件:
1、前端頁面,定義那些數(shù)據(jù)需要一次性拿到前端緩存,定義一個對象來保存這些數(shù)據(jù):
/** * 定義需要在用戶登錄的時候獲取到本地的數(shù)據(jù)字典類別 */ var clsCodes = {clsCodes : [BOOL, STATUS, USER_TYPE, REPORT_STATUS ] }; /** * 獲取數(shù)據(jù)字典到本地 */ var dicts;
2、前端頁面,定義一個函數(shù)來調用后臺接口獲取數(shù)據(jù),然后保存到本地緩存對象(dicts)中。
function getDicts() { $.post(getContextPath() + /api/sys/getDictList, clsCodes, function(resultBean, status, xhRequest) { if (resultBean.data != undefined) { dicts = resultBean.data; } }, 'json'); }
在主頁面加載的時候調用這個方法一次性獲取數(shù)據(jù)并緩存起來。這樣,以后需要同樣的數(shù)據(jù),就直接從本地對象dicts中獲取了。
后端Controller:
3、定義一個接口,根據(jù)前端的請求,查詢數(shù)據(jù)庫(或查詢服務器緩存,如下面例子中)獲取數(shù)據(jù)返回給前端:
/** * 根據(jù)多個分類編號獲取多個字典集合 * @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,>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- 輕松掌握JavaScript代理模式
- JavaScript設計模式之代理模式詳解
- JavaScript的設計模式經典之代理模式
- JavaScript設計模式之代理模式簡單實例教程
- js 設置緩存及獲取設置的緩存
- JavaScript設計模式之觀察者模式(發(fā)布訂閱模式)原理與實現(xiàn)方法示例
- JavaScript設計模式之工廠模式和抽象工廠模式定義與用法分析
- JavaScript設計模式之構造器模式(生成器模式)定義與用法實例分析
- JavaScript設計模式之單例模式原理與用法實例分析
- JavaScript設計模式之原型模式分析【ES5與ES6】
- JavaScript設計模式之緩存代理模式原理與簡單用法示例
相關文章
小程序實現(xiàn)頁面跳轉與數(shù)據(jù)傳遞方案
在開發(fā)過程中經常會遇到在微信小程序的頁面跳轉以及數(shù)據(jù)傳遞的知識點,所以下面這篇文章主要給大家介紹了關于小程序實現(xiàn)頁面跳轉與數(shù)據(jù)傳遞的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-09-09layui輸入框中只允許輸入整數(shù)的實現(xiàn)方法
今天小編就為大家分享一篇layui輸入框中只允許輸入整數(shù)的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09微信小程序動態(tài)設置導航欄標題的實現(xiàn)步驟
實際開發(fā)中很多時候我們需要通過上個頁面?zhèn)鬟^來的值動態(tài)的更改標題欄文字,下面這篇文章主要給大家介紹了關于微信小程序動態(tài)設置導航欄標題的實現(xiàn)步驟,需要的朋友可以參考下2023-02-02