最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

让回调函数showResponse也带上参数的代码_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 20:37:46
文档

让回调函数showResponse也带上参数的代码_javascript技巧

让回调函数showResponse也带上参数的代码_javascript技巧:function demo(){ var url=ajaxdemo.asp; var paras = ; var myAjax = new Ajax.Request( url, { method: 'post', parameters: paras, onComplete: showResponse }); } function showResponse(originalRequest){ var html = originalRequest.responseTex
推荐度:
导读让回调函数showResponse也带上参数的代码_javascript技巧:function demo(){ var url=ajaxdemo.asp; var paras = ; var myAjax = new Ajax.Request( url, { method: 'post', parameters: paras, onComplete: showResponse }); } function showResponse(originalRequest){ var html = originalRequest.responseTex


function demo(){
var url="ajaxdemo.asp";
var paras = "" ;
var myAjax = new Ajax.Request(
url,
{
method: 'post',
parameters: paras,
onComplete: showResponse
});
}
function showResponse(originalRequest){
var html = originalRequest.responseText;
alert(html);
}


这是应用 prototype.js 后最常看见的ajax代码,由于 showResponse 不能直接带参数,在处理回调函数时有时候比较麻烦,比如要把返回的html值动态插入到某个元素里面去。今天终于想到了一种方法来解决这个问题:


function demo(){
var url="ajaxdemo.asp";
var paras = "" ;
var myAjax = new Ajax.Request(
url,
{
method: 'post',
parameters: paras,
onComplete: function(originalRequest){showResponse(originalRequest,elemID)}
});
}
function showResponse(originalRequest,elemID){
var html = originalRequest.responseText;
$(elemID).innerHTML = html;
}


匿名函数这时充当了回调函数,而showResponse则变成一个普通方法了。变换了概念,问题就顺利解决。
解决了这个问题,还可以把这两个函数封装为一个函数:


function demo(url,paras,updateElemID){
var myAjax = new Ajax.Request(
url,
{
method: 'post',
parameters: paras,
onComplete: function(originalRequest){showResponse(originalRequest,updateElemID)}
});
}
function showResponse(originalRequest,elemID){
var html = originalRequest.responseText;
$(elemID).innerHTML = html;
}


只需要调用 demo(url,paras,updateElemID) 就能完成ajax的功能。爽。如果参数再扩展一下,增加一些动作函数,就不止是update某个元素的innerHTML这么简单了。

文档

让回调函数showResponse也带上参数的代码_javascript技巧

让回调函数showResponse也带上参数的代码_javascript技巧:function demo(){ var url=ajaxdemo.asp; var paras = ; var myAjax = new Ajax.Request( url, { method: 'post', parameters: paras, onComplete: showResponse }); } function showResponse(originalRequest){ var html = originalRequest.responseTex
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top