我有一个函数应该从sessionStorage返回一个字典(如果存在),如果不存在,它会将API中的字典加载到sessionStorage中,然后返回字典。
self.getDictionary = function(dictionary){
var deferred = $q.defer();
var saved_dictionary = JSON.parse($window.sessionStorage.getItem('dictionary_' + dictionary));
if (saved_dictionary && saved_dictionary !== "null"){
deferred.resolve(saved_dictionary);
} else {
var apiData = {module: "Dictionaries", method: "getDictionary", data: {name: dictionary}};
apiService.execute(apiData).then(function (response) {
$window.sessionStorage.setItem('dictionary_' + dictionary, JSON.stringify(response));
deferred.resolve(response);
});
}
return deferred.promise;
};
我正在尝试缓存字典,因为它可能非常大(大约0.5mb JSON)。
示例字典:
{"DictionaryName":"Gaming","DictionaryCategory":[{"CategoryName":"Games","MandatoryAtLeast":1,"CategoryWords":[{"title":"zelda","score":1,"exact":true,"mandatory":false,"reject":false},{"title":"mass effect","score":1,"exact":false,"mandatory":true,"reject":false},{"title":"pokemon","score":1,"exact":false,"mandatory":true,"reject":false},{"title":"fallout","score":1,"exact":false,"mandatory":false,"reject":false},{"title":"cs:go","score":1,"exact":true,"mandatory":false,"reject":false},{"title":"sims","score":1,"exact":false,"mandatory":false,"reject":false},{"title":"until dawn","score":1,"exact":false,"mandatory":false,"reject":false},{"title":"deus ex","score":1,"exact":false,"mandatory":false,"reject":false},{"title":"skyrim","score":1,"exact":false,"mandatory":true,"reject":false}]},{"CategoryName":"Companies","MandatoryAtLeast":1,"CategoryWords":[{"title":"bioware","score":1,"exact":false,"mandatory":true,"reject":false},{"title":"bethesda","score":1,"exact":false,"mandatory":false,"reject":false},{"title":"steam","score":1,"exact":false,"mandatory":true,"reject":false},{"title":"valve","score":1,"exact":false,"mandatory":false,"reject":false},{"title":"alienware","score":1,"exact":false,"mandatory":false,"reject":false}]},{"CategoryName":"other","MandatoryAtLeast":1,"CategoryWords":[{"title":"gamer","score":1,"exact":false,"mandatory":true,"reject":false},{"title":"mods","score":1,"exact":false,"mandatory":false,"reject":false},{"title":"horror","score":1,"exact":false,"mandatory":false,"reject":false},{"title":"survival","score":1,"exact":true,"mandatory":false,"reject":false},{"title":"multiplayer","score":1,"exact":false,"mandatory":false,"reject":false},{"title":"action","score":1,"exact":true,"mandatory":true,"reject":false},{"title":"fps","score":1,"exact":false,"mandatory":true,"reject":false},{"title":"shooter","score":1,"exact":false,"mandatory":false,"reject":false},{"title":"mmo","score":1,"exact":false,"mandatory":true,"reject":false}]}]}
问题是从缓存中提供字典无济于事。从sessionStorage提供字典所需的时间几乎与从远程API加载字典一样长。
为什么从sessionStorage返回需要这么长时间?
答案 0 :(得分:0)
调试后,似乎问题不在于sessionStorage。
问题是AngularJS花了一个年龄来渲染1000多个元素的ng-repeat。接下来我将不得不研究