如何在jQuery中缓存$ .post-request的结果?

时间:2010-01-03 18:54:59

标签: javascript jquery asp.net-mvc ajax caching

我有一个小的jQuery脚本,通过查看ID来获取信息。

防止多次请求相同数据的最佳方法是什么(例如,jQuery中缓存的最佳做法是什么)?

我尝试将$.post$.ajax选项“cache”设置为true,但请求被多次发送。

保存收集的数据和使用集合以确定是否需要请求它是否更好?

欢迎任何想法和建议!

如果重要,我在服务器端使用ASP.Net MVC。

1 个答案:

答案 0 :(得分:5)

您在文档中看到的cache选项是指浏览器的缓存。

您可以通过多种方式实现自记忆函数的模式,目标是确定参数的函数结果(在您的情况下为id)仅计算一次。 / p>

由于您使用的是Ajax请求,我建议您也使用回调参数,例如:

var getInfo = (function () {
  var cache = {}; // results will be cached in this object

  return function (id, callback) {
    if (cache[id] != null) { // if exist on cache
      callback(cache[id]);
      return;
    }
    // doesn't exists on cache, make Ajax request and cache it
    $.post("info.url", { "id": id }, function (data) { 
      cache[id] = data; // store the returned data
      callback(data);
    });
  };
})();

使用示例:

getInfo(5, function (data) {
  alert(data);
});