以下通话是否有意义/是否可能?
getCall('GET', URL, null, function(x, status, jqXHR){ }, failedRes);
function getCall(method, url, data, func, func2){
.ajax({
type: method,
contentType: "application/json",
data: data,
url: url,
dataType: "json"
}).done(function(data, textStatus,jqXHR) {
console.log("done");
}).fail(function(jqXHR, textStatus, err){
console.log("fail");
});
}
function func2(jqXHR, textStatus, errorThrown){
window.alert("AJAX call error occured");
console.error( errorThrown );
}
我最想知道的是因为“{}”,还因为参数。 函数参数“function(data,textStatus,jqXHR){}”太多了吗?而{}不正确?
答案 0 :(得分:1)
function(x, status, jqXHR){ }
定义了一个可以被调用的函数,但是当它被调用时,它除了返回undefined
之外什么都不做。在某些情况下,这可能是故意的。
在这种情况下,我想知道为什么该参数存在,因为getCall
甚至不使用参数func
。
答案 1 :(得分:0)
您可以传递任何内容。就个人而言,我喜欢以更加结构化的方式设置数据传递,以防将来需要更新。传递函数引用或函数本身是完全可行的。
ALA:
var data = {
call: "GET",
url: URL,
data: null,
func: function(x, status,jqXHR){},
func2: failedRes
}
getCall(data);
function getCall(data){
data = data || {};
// then just access your vars like so: data.url
答案 2 :(得分:0)
是的,这有效。
function callFunction(func, param) {
return func(param);
}
callFunction(
function(a) {
return a*2;
},
2
);
返回4
答案 3 :(得分:0)
这是JavaScript AJAX请求/响应格式:
function xhr(method, url, send, success){
var x = new XMLHttpRequest || new ActiveXObject('Microsoft.XMLHTTP');
var v = send ? encodeURI(send) : null;
method = method.toUpperCase();
x.open(method, url);
if(method.match(/^POST$/)){
x.setRequestHeader('Content-type', 'application/x-www-form-urlencoded');
x.setRequestHeader('Content-length', v.length); x.setRequestHeader('Connection', 'close');
}
x.onreadystatechange = function(){
if(x.readyState === 4 && x.status === 200){
success(x.responseText);
}
}
x.send(v);
}