时间:2021-05-18
functiondemo(){
varurl="ajaxdemo.asp";
varparas="";
varmyAjax=newAjax.Request(
url,
{
method:'post',
parameters:paras,
onComplete:showResponse
});
}
functionshowResponse(originalRequest){
varhtml=originalRequest.responseText;
alert(html);
}
这是应用prototype.js后最常看见的ajax代码,由于showResponse不能直接带参数,在处理回调函数时有时候比较麻烦,比如要把返回的html值动态插入到某个元素里面去。今天终于想到了一种方法来解决这个问题:
functiondemo(){
varurl="ajaxdemo.asp";
varparas="";
varmyAjax=newAjax.Request(
url,
{
method:'post',
parameters:paras,
onComplete:function(originalRequest){showResponse(originalRequest,elemID)}
});
}
functionshowResponse(originalRequest,elemID){
varhtml=originalRequest.responseText;
$(elemID).innerHTML=html;
}
匿名函数这时充当了回调函数,而showResponse则变成一个普通方法了。变换了概念,问题就顺利解决。
解决了这个问题,还可以把这两个函数封装为一个函数:
functiondemo(url,paras,updateElemID){
varmyAjax=newAjax.Request(
url,
{
method:'post',
parameters:paras,
onComplete:function(originalRequest){showResponse(originalRequest,updateElemID)}
});
}
functionshowResponse(originalRequest,elemID){
varhtml=originalRequest.responseText;
$(elemID).innerHTML=html;
}
只需要调用demo(url,paras,updateElemID)就能完成ajax的功能。爽。如果参数再扩展一下,增加一些动作函数,就不止是update某个元素的innerHTML这么简单了。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在类C语言中通常通过函数指针/引用的方式传递。jquery也提供类似的回调函数机制。但是如何正确传递回调函数仍然值得一提。1、不带参数的回调复制代码代码如下:$
首先我们前面介绍过,replace()方法中的第二个参数若是回调函数,那么这个回调函数中的参数就是匹配成功后的结果。。。。。,那么有没有考虑回调函数中有多个参数
node里几乎所有用到回调函数的地方,都是异步的,回调函数后面的代码很可能比回调函数中的代码后先执行,特别是数据库操作。当然,node也提供了同步版本的函数,例
一、回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。回调
回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用为调用它所指向的函数时,我们就说这是回调函数。回调函数