如何给JQ的ajax方法中的success()传入参数?

当时在使用JQuery提供的Ajax技术的时候,我有个需求,就是要给它请求成功后调用的success()方法传入参数;

所以,我就直接这样子写了:

<script>
function getTypeList(name){
  $.ajax({
    url : '<c:url value="admin/type_loadTypeList.action"/>',
    type : 'get',
    contentType : "text/html;charset=utf-8",
    dataType : 'json',
    success : function(data,name) {      
          alert(name);//查看name的值
      mycallback(data,name);//回调函数
    }
    });
 }
</script>            

当时我传入name="Java"。

当我运行后,alert(name)返回的值却是“success”!!

怎么回事呢?

原来success: function(data,name)是Ajax在请求成功后自动调用的,所以这个方法是Ajax调用的,那么该方法的参数(data,name)便是Ajax提供的了。(js学的差了点,所以当时脑子没转过来)

其中function(data,name)的参数data是客户端请求后台,由后台返回的值。

参数name这是个比较特殊的参数名,因为刚刚好在Ajax中有个参数名也叫name,所以,Ajax就以为你是要它把它自己的参数name传进去。该name的值却刚好是"success";

如果你把function(data,name)的参数name改为其它的话,那么就不会返回为"success",而是返回为空字符串了。(当然还有可能你取了跟Ajax内部其它的参数名相同的名字,那么返回便是Ajax的参数的参数值了)

==============================解决================

那么问题来了:

给function()传入的参数名跟Ajax的参数名相同就会返回Ajax的参数值,这不是我们想要的。

但是,你穿入的参数名跟Ajax的参数名不同,就会找不到该参数值,这也不是我们想要的;(因为这个方法是由Ajax来调用,如果Ajax没有该参数,那么该参数就为空)

那么该怎么办呢?

其实,我们并不需要传入参数,直接在把name参数传给mybackdata(data,name),而不需要通过function()来传递。(此处的name参数是指getTypeList(name)中的name参数)

代码如下:

function getTypeList(name){
  $.ajax({
    url : '<c:url value="admin/type_loadTypeList.action"/>',
    type : 'get',
    contentType : "text/html;charset=utf-8",
    dataType : 'json',
    success : function(data) {
      mycallback(data,name);
    }
  });
}

总结:

Ajax的请求成功调用的方法中的参数是由Ajax负责传递。

本人文笔写的不太好,希望各位大牛多多点评指点。。

上一篇:7-zip命令行详解


下一篇:Android开发之漫漫长途 XII——Fragment详解