5

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

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

缓存仅在输入单个单词时起作用(“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(),
});

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

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

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

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

4

1 回答 1

3

正如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)
});

你可以在这里查看我的完整源代码

于 2015-01-04T20:23:49.693 回答