settimeout传递参数PHP,window_javascript setTimeout()传递函数参数(包括传递对象参数),于是,上网查找了一下,用了 - phpStudy...

本文探讨了在JavaScript中使用setTimeout()函数传递函数参数,特别是对象参数时遇到的问题。作者通过实践发现,常规的字符串化参数方法在某些情况下不适用,并分享了一种自定义的解决方案,即在函数内部保存对象引用,从而成功传递对象参数到setTimeout()。该方法适用于需要传递复杂对象的情况,但作者也指出,这种方法可能不适用于所有场景,欢迎读者提供更好的解决策略。
摘要由CSDN通过智能技术生成

javascript setTimeout()传递函数参数(包括传递对象参数)

于是,上网查找了一下,用了另一种写法setTimeout("fun("+参数+")", 1000),还是不行,但是以上写法在传递form表单的textarea是可以的,比如hml是这样:

复制代码 代码如下:

在js里边我可以这样子写:

setTimeout("doAjax(document.sform.txtara.value )", 1000);

但是一旦要传递其他什么参数或者是对象参数,按照网上提供的方法就是要重写这个函数了。

经过研究和实践,我自己改进了方法,大家可以参考借鉴一下,我只是依据我的个人需要,其他情况我也不能保证,请多多指教!

复制代码 代码如下:

JavaScript:

复制代码 代码如下:

function initAjax() {

var httprequest=null;

try {

httprequest=new ActiveXObject("Msxml2.XMLHTTP");

}

catch (e) {

try {

httprequest=new ActiveXObject("Microsoft.XMLHTTP");

}

catch (e) {

try {

httprequest=new XMLHttpRequest();

}

catch (e) {

httprequest=null;

}

}

}

return httprequest;

}

function doAjax( msg, obj ) {

var obj=obj; //主要是这一行

alert( obj.value);

var he="he="+msg;

var ajaxrequest=initAjax();

ajaxrequest.open("POST", "abc.jsp", true);

ajaxrequest.setRequestHeader( "Content-Type", "application/x-www-form-urlencoded;charset=utf-8");

ajaxrequest.send(he);

ajaxrequest.onreadystatechange=function() {

if (ajaxrequest.readyState==4) {

if (ajaxrequest.status==200) {

document.getElementById("showpane").innerHTML=ajaxrequest.responseText;

}

else {

doAjax( msg );

}

}

}

setTimeout("doAjax(document.sform.txtara.value,document.all["+obj.sourceIndex+"])", 100);//还有这一行

}

就这样,我解决了对象参数传递的问题,最后想说一句,能有更好的解决方法请作评论提出来,本人乐意与志同道合者学习!相关阅读:

一个qq菜单效果

SQL Server各种日期计算方法(收藏)

CSS学习之类目之间竖线的练习实例

如何跨站抓取别的站点的页面的补充

Win2000+Apache+MySql+PHP4+PERL安装使用小结

4.13 使用ASP建设私人的搜索引擎

dojo 之基础篇

在Linux系统下实现FTP虚拟主机的简单方法

Oracle 的位图索引简述

ASP3.0高级编程(五)

CSS教程:vertical-align的值

快速掌握外键约束和参绍约束

开放原代码的 Qmail+Mysql+Jsp 中文电子邮局系统说明

php你的验证码安全码?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值