使用 Algolia Instantsearch.js 库获得 JQuery 承诺
Get a JQuery promise using Algolia Instantsearch.js library
我正在使用 instantsearch.js 库来管理来自 Algolia API 的结果。
我想知道是否有办法通过 instantsearch.js 获得承诺?
我目前正在使用命令:
search.on('render', function() {
// code
});
执行我的代码,但我想在处理我的代码之前等待其他 ajax 异步结果。
我的目的是获得如下内容:
var request1 = $.ajax( url );
var request2 = $.ajax( url );
var result = search.on('render', function() {
// code
}
$.when(request1, request2, result).then(
function(){
console.log("success", arguments);
},
function(){
console.log("fail", arguments);
});
有人有解决办法吗?
非常感谢。
山姆
您可以在 render
事件处理程序
中创建延迟对象、解析或拒绝延迟对象
var request1 = $.ajax( url );
var request2 = $.ajax( url );
var result = new $.Deferred();
search.on('render', function() {
// code
result.resolve(/* value */);
})
$.when(request1, request2, result)
.then(
function() {
console.log("success", arguments);
},
function() {
console.log("fail", arguments);
});
承诺 "rendered" 事件的最简单方法是:
var request1 = $.ajax(url);
var request2 = $.ajax(url);
var rendered = $.Deferred(function(dfrd) {
search.on('render', dfrd.resolve);
});
$.when(request1, request2, rendered).then(function(result1, result2) {
console.log(result1, result2);
}, function(error) {
console.error(error);
});
虽然这里没什么大不了的,但 deferreds/promises 在性能方面相当昂贵。使用 :
您将以更低的成本获得相同的效果
var request1 = $.ajax(url);
var request2 = $.ajax(url);
search.on('render', function() {
$.when(request1, request2).then(function(result1, result2) {
console.log(result1, result2);
}, function(error) {
console.error(error);
});
});
我正在使用 instantsearch.js 库来管理来自 Algolia API 的结果。
我想知道是否有办法通过 instantsearch.js 获得承诺?
我目前正在使用命令:
search.on('render', function() {
// code
});
执行我的代码,但我想在处理我的代码之前等待其他 ajax 异步结果。
我的目的是获得如下内容:
var request1 = $.ajax( url );
var request2 = $.ajax( url );
var result = search.on('render', function() {
// code
}
$.when(request1, request2, result).then(
function(){
console.log("success", arguments);
},
function(){
console.log("fail", arguments);
});
有人有解决办法吗?
非常感谢。
山姆
您可以在 render
事件处理程序
var request1 = $.ajax( url );
var request2 = $.ajax( url );
var result = new $.Deferred();
search.on('render', function() {
// code
result.resolve(/* value */);
})
$.when(request1, request2, result)
.then(
function() {
console.log("success", arguments);
},
function() {
console.log("fail", arguments);
});
承诺 "rendered" 事件的最简单方法是:
var request1 = $.ajax(url);
var request2 = $.ajax(url);
var rendered = $.Deferred(function(dfrd) {
search.on('render', dfrd.resolve);
});
$.when(request1, request2, rendered).then(function(result1, result2) {
console.log(result1, result2);
}, function(error) {
console.error(error);
});
虽然这里没什么大不了的,但 deferreds/promises 在性能方面相当昂贵。使用 :
您将以更低的成本获得相同的效果var request1 = $.ajax(url);
var request2 = $.ajax(url);
search.on('render', function() {
$.when(request1, request2).then(function(result1, result2) {
console.log(result1, result2);
}, function(error) {
console.error(error);
});
});