我正在使用twitter typeahead javascript库预先填充搜索字词,以帮助用户搜索特定名称。我正在使用他们的示例substringMatcher
函数,该函数可以在here中找到。
我正在使用Ajax调用填充我的数据,该调用返回我期望的数据。然后将此数组传递给该示例substringMatcher
函数,但是在搜索时将返回整个数组,而不是每个单独的项(请参见图片)。
它应该只返回个人名称,而不是数组!
在这里,他是我的预先输入功能和来源;
$('input#practition-typeahead').typeahead({
hint: true,
highlight: true,
minLength: 3,
},{
name: 'output',
source: substringMatcher(
jQuery.ajax({
type: "POST",
url: "/wp-admin/admin-ajax.php",
dataType: "json",
data: {
action: 'get_all_practitioners'
},
success:function(output){
return output;
}
})
)
});
我的子字符串匹配器功能
var substringMatcher = function(strs) {
return function findMatches(q, cb) {
var matches, substringRegex;
// an array that will be populated with substring matches
matches = [];
// regex used to determine if a string contains the substring `q`
substrRegex = new RegExp(q, 'i');
// iterate through the pool of strings and for any string that
// contains the substring `q`, add it to the `matches` array
$.each(strs, function(i, str) {
if (substrRegex.test(str)) {
matches.push(str);
}
});
cb(matches);
};
};
编辑-
当我从ajax的console.log
output
success
我得到以下内容:
success:function(output){
console.log(output);
return output;
}
答案 0 :(得分:2)
我已经解决了这个问题,只需将我的提前输入实例延迟到ajax调用完成为止。完整的代码可以在下面找到;
var output = [];
jQuery.ajax({
type: "POST",
url: "/wp-admin/admin-ajax.php",
dataType: "json",
data: {
action: 'get_all_practitioners'
},
success:function(output){
console.log(output);
return output;
}
}).done(function(output){
$('input#practition-typeahead').typeahead({
hint: true,
highlight: true,
minLength: 1,
},{
name: 'output',
source: substringMatcher(
output
)
});
});