在 JQuery 中是否可以跳过可选参数并传递下一个参数?如果是,jquery 函数如何确定哪个值对应哪个参数?
一个例子:
//
// function signature is
// jQuery.get( url [, data] [, success(data, textStatus, jqXHR)] [, dataType] )
//
// function is called as
//
$.get('ajax/test.html', function (data) {
$('.result').html(data);
alert('Load was performed.');
});
在 url 之后调用 $.get() 时,跳过 [, data],然后传递成功回调。
最佳答案
是的,可以跳过可选参数,甚至可以从中间开始。 jQuery 查看参数的类型来确定哪个是哪个。看看 jQuery.load
的签名:
.load(url [, data] [, complete(responseText, textStatus, XMLHttpRequest)])
下面的工作按预期进行:
.load("test.php")
.load("test.php", {foo: bar})
.load("test.php", {foo: bar}, function(){})
.load("test.php", function(){}) // you skipped the 2nd parameter? no.
您会注意到这三个参数是:string
、object
和function
。在函数内部,jQuery 可以轻松检查传递了多少参数及其类型。如果它注意到第二个参数是一个函数,它将假定 data
参数被跳过并采取相应的行动。
令您惊讶的是,还有另一个 jQuery.load
具有不同签名的功能完全不同:
.load(handler(eventObject))
.load([eventData], handler(eventObject))
同样,jQuery 可以通过查看参数来确定触发哪个方法。
关于javascript - 在 JQuery 中是否可以跳过可选参数并传递下一个参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12125968/