Bloodhound不会缓存本地存储中远程提取的数据

Mak*_*dis 5 caching local-storage typeahead.js bloodhound

我正在尝试为typeahead加载人名的自动完成信息,如果我已经有结果,则不必再次查询服务器.

例如,如果我搜索一个人的名字,并且从远程查询中检索该人的数据(以及其他人),当我删除该名称并搜索姓氏时,我希望将以前缓存的名称与该姓氏一起显示.实际发生的是,再次从服务器和建议中检索结果.

缓存仅在键入单个单词时有效("Mic" - >"Mich" - >"Micha" - >"Michael").

TL; DR:我想在本地存储中缓存来自本地存储中的猎犬的结果,不仅来自预取(不能应用于我的情况),而是来自远程,并在再次查询远程之前使用它.

我现在拥有的是什么

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(),
});
Run Code Online (Sandbox Code Playgroud)

我没有找到类似的东西,我担心没有这个简单的解决方案.

PS:我也注意到datumTokenizer永远不会被调用

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

当我使用它时,"Lalalalala"从未在chrome调试控制台中输出.

Bre*_*ody 3

正如jhardinglocalstorage提到的,此时不可能提取远程建议。

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

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

然后,我检索了该数组以在 typeahead 字段中使用。

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

您可以在此处查看我的完整源代码