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


Posted in Javascript onAugust 13, 2007

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这么简单了。

Javascript 相关文章推荐
JavaScript在浏览器标题栏上显示当前日期和时间的方法
Mar 19 Javascript
微信小程序 radio单选框组件详解及实例代码
Jan 10 Javascript
完美解决input[type=number]无法显示非数字字符的问题
Feb 28 Javascript
JS/jquery实现一个网页内同时调用多个倒计时的方法
Apr 27 jQuery
基于 Vue 的树形选择组件的示例代码
Aug 18 Javascript
bootstrap table实现点击翻页功能 可记录上下页选中的行
Sep 28 Javascript
JavaScript模拟实现封装的三种方式及写法区别
Oct 27 Javascript
微信小程序实现人脸识别
May 25 Javascript
ES6 Generator函数的应用实例分析
Jun 26 Javascript
vue-cli设置publicPath小记
Apr 14 Javascript
让IDE识别webpack的别名alias的实现方法
May 06 Javascript
vue根据条件不同显示不同按钮的操作
Aug 04 Javascript
分析 JavaScript 中令人困惑的变量赋值
Aug 13 #Javascript
IE/FireFox具备兼容性的拖动代码
Aug 13 #Javascript
JavaScript 编程引入命名空间的方法与代码
Aug 13 #Javascript
权威JavaScript 中的内存泄露模式
Aug 13 #Javascript
封装好的省市地区联动控件附下载
Aug 13 #Javascript
分享别人写的一个小型js框架
Aug 13 #Javascript
javascript下查找父节点的简单方法
Aug 13 #Javascript
You might like
PHP 文件上传功能实现代码
2009/06/24 PHP
关于mysql字符集设置了character_set_client=binary 在gbk情况下会出现表描述是乱码的情况
2013/01/06 PHP
Android ProgressBar进度条和ProgressDialog进度框的展示DEMO
2013/06/19 PHP
Mac系统下搭建Nginx+php-fpm实例讲解
2020/12/15 PHP
jQuery操作select的实例代码
2012/06/14 Javascript
jquery实现点击变换导航样式的方法
2015/08/31 Javascript
javascript实现简单的全选和反选功能
2016/01/05 Javascript
js实现不重复导入的方法
2016/03/02 Javascript
Js删除数组中某一项或几项的几种方法(推荐)
2016/07/27 Javascript
通过JS获取Request.QueryString()参数的值实现方法
2016/09/27 Javascript
Bootstrap CSS使用方法
2016/12/23 Javascript
[js高手之路]设计模式系列课程-发布者,订阅者重构购物车的实例
2017/08/29 Javascript
不使用JavaScript实现菜单的打开和关闭效果demo
2018/05/01 Javascript
JavaScript实现连连看连线算法
2019/01/05 Javascript
[jQuery] 事件和动画详解
2019/03/05 jQuery
Vue.js页面中有多个input搜索框如何实现防抖操作
2019/11/04 Javascript
vue使用一些外部插件及样式的配置代码
2019/11/18 Javascript
JavaScript实现无限轮播效果
2020/11/19 Javascript
mapboxgl实现带箭头轨迹线的代码
2021/01/04 Javascript
js实现鼠标切换图片(无定时器)
2021/01/27 Javascript
[01:18:31]DOTA2-DPC中国联赛定级赛 LBZS vs Magma BO3第一场 1月10日
2021/03/11 DOTA
python监控网站运行异常并发送邮件的方法
2015/03/13 Python
Python使用Flask框架获取当前查询参数的方法
2015/03/21 Python
Python基础知识_浅谈用户交互
2017/05/31 Python
django创建最简单HTML页面跳转方法
2019/08/16 Python
解决Tensorflow占用GPU显存问题
2020/02/03 Python
Pycharm和Idea支持的vim插件的方法
2020/02/21 Python
GUESS Factory加拿大:牛仔裤、服装及配饰
2019/09/20 全球购物
大学社团活动策划书
2014/01/26 职场文书
完美主义个人的自我评价
2014/02/17 职场文书
学校党员个人问题整改措施思想汇报
2014/10/08 职场文书
税务干部个人整改措施思想汇报
2014/10/10 职场文书
教师年度个人总结
2015/02/11 职场文书
让人感觉高大上的讲话稿怎么写?
2019/07/08 职场文书
面试必问:圣杯布局和双飞翼布局的区别
2021/05/13 HTML / CSS
Python实现为PDF去除水印的示例代码
2022/04/03 Python