我正在使用JQuery插件为我的项目开发一个“自动完成”功能,我需要将来自两个不同来源(数据库表)的建议(匹配结果)显示给用户,这意味着需要为两个请求发送ajax请求网址一次。
有可能吗?
如果我对此有任何建议,请高兴
答案 0 :(得分:2)
使用javascript函数作为自动完成的源。您可以在内部执行两个ajax请求,并将响应合并为一个。
$('#myinput').autocomplete({
source: function(data, callback) {
$.ajax(firstUrl, {
...,
success: function(result1) {
$.ajax(secondUrl, {
success: function(result2) {
var mergedResults = result1.concat(result2);
callback(mergedResults);
}
});
},
}
}
答案 1 :(得分:1)
我为jsdocu.com撰写了一些内容。但这里只是一个搜索来源。但是,根据您的需要改变它并不是很难。
/** delayR by Yannick Albert | https://gist.github.com/3729753 **/
var delayR = function(a,b,c,d){c=null;return function(){d=this;clearTimeout(c);c=setTimeout(function(){a.apply(d,arguments)},b)}};
$("#s").bind('click keyup', delayR(function() {
var term = this.value,
url = $('#searchform').attr('action');
if (term) {
$.post(url, {
s: term
}, function(data) {
var content = $(data).find('.hentry');
if (content.length !== 0) {
$("#autocomplete").fadeIn().empty().append(content);
} else {
$("#autocomplete").hide();
}
});
} else {
$("#autocomplete").fadeOut();
}
}, 300));
答案 2 :(得分:0)
是的,这是可能的,但这是2个问题。使用Microsoft发明的原始ajax对象,您无法同时发出多个请求。有很多脚本可以实现这一点,但你是一个幸运的家伙,jQuery已经很幸运了。另一个问题是关于自动完成功能,可以通过trie数据结构解决。它可以有效地存储大型词典。