[b]1.问题描述[/b]
想给$.post()的回调方法传递多个参数,如果把回调函数放在post方法之外定义,始终传递不过去,如:
可以看到这种方法,默认不需要传递参数,data就是post方法调用由服务器返回的json数据。
按照这样的思路,自定义参数传递写成:
这样就会在post调用回调的地方报错,data没有定义。如果把data删掉只留myParam,则传参只会把第一个参数data当做是myParam。
[b]2. 半解决办法[/b]
最后没办法,只得在post的调用里面直接定义回调方法,写成:
[code]function getLatestReceivedSms()
{
var myParam = 'aa';
// error: data未定义
$.get("/smsplatform/smsplatform/S_SmsManager_queryLatestReceivedSms.action", {senderId:smsSenderId}, function receiveSmsCallback(data)
{
var result = $.parseJSON(data);
alert(myParam);
...
});
}
[/code]
利用参数的可见性,直接在回调方法里使用myParam即可。还是没有通过传参。
在这里定义的时候可以多几个参数,比如function( data, textStatus, jqXHR ),data就是后台传来的结果,textStatus代表post调用的结果是"success"还是"fail"
可以参考:
[url]http://www.365mini.com/page/jquery_ajax.htm[/url]
[url]http://love398146779.iteye.com/blog/1177332[/url]
想给$.post()的回调方法传递多个参数,如果把回调函数放在post方法之外定义,始终传递不过去,如:
//接收短信
function getLatestReceivedSms()
{
$.get("/smsplatform/smsplatform/S_SmsManager_queryLatestReceivedSms.action", {senderId:smsSenderId}, receiveSmsCallback);
}
// 回调方法
function receiveSmsCallback(data)
{
var result = $.parseJSON(data);
...
}
可以看到这种方法,默认不需要传递参数,data就是post方法调用由服务器返回的json数据。
按照这样的思路,自定义参数传递写成:
//接收短信
function getLatestReceivedSms()
{
var myParam = 'aa';
// error: data未定义
$.get("/smsplatform/smsplatform/S_SmsManager_queryLatestReceivedSms.action", {senderId:smsSenderId}, receiveSmsCallback(data, myParam));
}
// 回调方法
function receiveSmsCallback(data, myParam)
{
var result = $.parseJSON(data);
...
}
这样就会在post调用回调的地方报错,data没有定义。如果把data删掉只留myParam,则传参只会把第一个参数data当做是myParam。
[b]2. 半解决办法[/b]
最后没办法,只得在post的调用里面直接定义回调方法,写成:
[code]function getLatestReceivedSms()
{
var myParam = 'aa';
// error: data未定义
$.get("/smsplatform/smsplatform/S_SmsManager_queryLatestReceivedSms.action", {senderId:smsSenderId}, function receiveSmsCallback(data)
{
var result = $.parseJSON(data);
alert(myParam);
...
});
}
[/code]
利用参数的可见性,直接在回调方法里使用myParam即可。还是没有通过传参。
在这里定义的时候可以多几个参数,比如function( data, textStatus, jqXHR ),data就是后台传来的结果,textStatus代表post调用的结果是"success"还是"fail"
可以参考:
[url]http://www.365mini.com/page/jquery_ajax.htm[/url]
[url]http://love398146779.iteye.com/blog/1177332[/url]