函数调用中的参数的javascript函数可能吗?

时间:2013-12-28 23:16:37

标签: javascript jquery function parameters

以下通话是否有意义/是否可能?

    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){}”太多了吗?而{}不正确?

4 个答案:

答案 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);
}