作者awpadam (三疯)
看板Ajax
标题[问题] 关於物件与计时器
时间Wed Mar 5 20:43:05 2008
请问各位前辈
以下,我想重复执行某个物件的某个method
但是为甚麽程式不是一秒增加一个a,而是瞬间增加无数个a
<html>
<body>
<input id="test" type="text" >
<script>
addtext=function(){
this.add=function(){
document.getElementById('test').value+='a';
setTimeout(this.add(),1000);
}
}
var myobj = new addtext();
myobj.add();
</script>
</body>
</html>
把程式改成这样後正常执行
<html>
<body>
<input id="test" type="text" >
<script>
addtext=function(){
this.add=function(){
document.getElementById('test').value+='a';
}
}
var myobj = new addtext();
setInterval("myobj.add()",1000);
</script>
</body>
</html>
虽然正常执行了,不过我的add函式他本身想要的功能就是自己无限的执行
而不是必须靠全域使用setInterval
请问该怎麽解呢?
再来还有个小问题
为甚可以正常执行的那段中的setInterval("myobj.add()",1000);
如果第一个参数没有加上双引号变成字串,是不能执行的呢(难道他用eval在实做?)
以上
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 218.211.22.196
1F:推 blackbing:this.add()改成this.add就行了;) 03/05 22:04
2F:→ awpadam:我改成this.add之後还是有一点问题说 03/06 01:04
3F:→ awpadam:他会出现第二个a,然後就停止了y 03/06 01:04
4F:→ awpadam:在firefox的错误中出现 03/06 01:04
5F:→ awpadam:useless setTimeout call (missing quotes around argumen 03/06 01:05
6F:→ awpadam:因此我改成"this.add" 03/06 01:05
7F:→ awpadam:结果只跑出一个a,但是在firefox中没有出现错误讯息 03/06 01:06
8F:→ awpadam:整个就另我苦恼阿= =. 希望各位前辈解惑 03/06 01:07