caching - Bloodhound 不会将远程获取的数据缓存在本地存储中

标签 caching local-storage typeahead.js bloodhound

我正在尝试加载人名的自动完成信息以进行提前输入,然后如果我已经有了结果,则不必再次查询服务器。

例如,如果我搜索一个人的姓名,并且从远程查询中检索该人(以及其他人)的数据,那么当我删除该姓名并搜索姓氏时,我希望获得以前缓存的带有该姓氏的姓名现身。实际发生的是再次从服务器检索结果和建议。

缓存仅在输入单个单词时起作用(“Mic”->“Mich”->“Micha”->“Michael”)。

TL;DR:我不仅想在本地存储中缓存 Bloodhound 的结果(这不能应用于我的情况),还想从远程缓存结果,并在再次查询远程之前使用它。

我目前拥有的是

function dispkey(suggestion_object){
  console.log(suggestion_object);
  return suggestion_object["lastname"] + ", " + suggestion_object["firstname"];
}

var engine = new Bloodhound({
  name: 'authors',
  local: [],
  remote: 'http://xxxxxx.xxx/xxxx/xxxxxxxxxx?query=%%QUERY',
  datumTokenizer: function(d) {
    return Bloodhound.tokenizers.whitespace(d.val);
  },
  queryTokenizer: function (s){
    return s.split(/[ ,]+/);
  },
});

engine.initialize();

$('.typeahead').typeahead({
    highlight: true,
    hint: true,
    minLength: 3,
},
{
  displayKey: dispkey,
  templates: {
     suggestion: Handlebars.compile([
      '<p id="author_autocomplete_email_field" >{{email}}</p>',
      '<p id="author_autocomplete_name_field">{{lastname}} {{firstname}}</p>',
      ].join(''))},
  source: engine.ttAdapter(),
});

我还没有找到类似的东西,而且恐怕没有简单的解决方案。

P.S.:我还注意到 datumTokenizer 永远不会被调用

datumTokenizer: function(d) {
    console.log("Lalalalala");
    return Bloodhound.tokenizers.whitespace(d.val);
  },

当我使用这个时,“Lalalalala”从未在 Chrome 调试控制台中输出。

最佳答案

jharding提到目前无法从 localstorage 中提取远程建议。

但是,我最近从事一个小项目,我需要存储以前的表单输入以供将来在 typeahead.js 中使用。为此,我将表单输入值数组保存到 localstorage 中。

var inputs = ['val1', 'val2', 'val3', 'val4'];
localStorage.setItem('values', JSON.stringify(inputs));

然后我检索了用于 typeahead 字段的数组。

var data = JSON.parse(localStorage.getItem('values'));
$('input').typeahead({
    minLength: 3,
    highlight: true,
},
{
    name: 'data',
    displayKey: 'value',
    source: this.substringMatcher(data)
});

您可以查看我的full source here .

关于caching - Bloodhound 不会将远程获取的数据缓存在本地存储中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22143796/

相关文章:

apache - 透明的 "inside each"负载平衡的Web服务器能正常工作吗?

javascript - 解析本地存储对象会出现未捕获的语法错误?

swift - 解析错误代码 151

javascript - Twitter Typeahead.js 库是否仅限于 6 个数据集?

javascript - 带有远程数组的 Twitter typeahead.js

node.js - 使用 Redis 的 NodeJs 缓存

c++ - 应用程序的缓存友好设计

caching - 缓存集群部署拓扑

javascript - 是否可以在 localStorage 中缓存外部库?

javascript - 为什么 Twitter 的 typeahead.js 不能与我的 JSON 配合使用?