gpt4 book ai didi

javascript - 如何为链接回调实现类似 jquery 的 'success' 和 'failure' 函数

转载 作者:塔克拉玛干 更新时间:2023-11-02 22:24:51 24 4
gpt4 key购买 nike

我是 javascript 的新手,我需要链接函数执行,但函数对成功和失败的 react 不同。函数数组作为参数获取,如果成功,则前一个结果是链中下一个的输入参数,在错误情况下,我可以定义一些警报/日志行为。我喜欢 jquery 对 GET ajax 方法成功和失败的示例。如何使该内部函数触发这些事件,这是如何在 javascript 中实现的?

最佳答案

两种解决方案的现场演示 here (click).

Promises 现在被认为是最好的方法,而不是回调。我将从回调开始,因为它们更容易上手,然后再讨论 promises。

带对象参数的基本回调:

//change this to true or false to make the function "succeed" or "fail"
//var flag = false;
var flag = true;

//this is the function that uses "success" and "error"
function foo(params) {
//some condition to determine success or failure
if (flag) {
//call the success function from the passed in object
params.success();
}
else {
//call the error function from the passed in object
params.error();
}
}

//function "foo" is called, passing in an object with success and error functions
foo({
success: function() {
console.log('success!');
},
error: function() {
console.log('error!');
}
});

确保在触发回调之前传入回调:

对于完整的解决方案,您还需要在调用它们之前确保这些属性存在 - 只有在传入它们时才调用成功和错误函数。

这是我将如何做到的:

if (flag) {
//the function is only fired if it exists
params.success && params.success();
}

作为单独参数传入的回调:

您不必将它们传递到一个对象中。您可以只让函数接受单独的参数:

function foo(success, error) {
if (flag) {
success && success();
}
else {
error && error();
}
}

foo(
function() {
console.log('success!');
},
function() {
console.log('error!');
}
);

单独或在对象中传递的回调:

您还可以让函数根据传入的内容使用对象中的单个参数或函数。您只需检查第一个参数是函数还是对象,然后相应地使用它:

function foo(success, error) {
if (arguments.length === 1 && typeof arguments[0] === 'object') {
var params = arguments[0];
success = params.success;
error = params.error;
}
if(flag) {
success && success();
}
else {
error && error();
}
}

foo(function() {
console.log('success');
});

foo({
success: function() {
console.log('success!');
}
});

promise !万岁!

正如我所说,我非常喜欢使用 promises,它非常适合处理异步函数。这将需要一个 promise 库或 ES6 JavaScript。这就是 jQuery 的样子。大多数库都是相似的:

function bar() {
var deferred = new $.Deferred();

if (flag) {
//if you resolve then, the first "then" function will fire
deferred.resolve();
}
else {
//if you reject it, the second "then" function will fire
deferred.reject();
}

return deferred.promise();
}

//since "bar" returns a promise, you can attach a "then" function to it
//the first function will fire when the promise is resolved
//the second function will fire when the promise is rejected
bar().then(function() {
console.log('bar success!');
},
function() {
console.log('bar error!');
});

使用 JavaScript ES6 Promise:

function bar() {
return new Promise(function(resolve, reject) {
if (flag) {
resolve()
}
else {
reject();
}
})
}

Promises 一开始可能很难理解。有很多很好的教程可以帮助您全神贯注。

关于javascript - 如何为链接回调实现类似 jquery 的 'success' 和 'failure' 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21358186/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com