jQuery中的setTimeout用法

昨天开始写页面的翻页效果,遇到setTimeout的难题,今天才得以解决.

开始时我遇到的问题是

function shiyan1(){
       alert();
}
$("img").click(function(){
       setTimeout(shiyan1(), 2000);
})


这个问题肯定很多人犯,这个程序不会在两秒后执行,而是直接执行,因为你写了括号,他就直接调用了shiyan1()函数,

而你写    setTimeout(shiyan1, 2000);  就不会出这个问题

但是问题是要是你传参数怎么办呢

于是我找了不少资料,总于在网上找到了,以下内容出自

http://www.studyday.net/2011/01/177 




jQuery 中 setTimeout/setInterval 不能像在原生态 javascript 中那样使用, 否则会报错.
我们通过例子来说明一下jQuery中setTimeout的几种使用方法, 首先准备好测试用的DIV和公共函数:

<div id="div_debug"></div>
<script src="http://www.studyday.net/demo/jquery.js"></script>
<script language="JavaScript">
    function log(s){
         $('#div_debug').append(s+'<br>');
    }

//下文中测试用的代码可以放在这一行注释的下面,替换掉 //...
//...

</script>


原生态 javascript 中的 setTimeout 基本用法是像这样子的.

//原生态 javascript 中的 setTimeout 基本用法
function funA(){
      log('funA...');
      setTimeout('funA()', 1000);
}
funA();


下面是jQuery中setTimeout的几种使用方法在线实例

//jQuery 中的用法
function funA(){
    log('funA...');
    setTimeout('funA()', 1000);
}

jQuery(document).ready(function($){
     //用法1 : 把要调用的函数写在ready外面,使它成为全局函数
    funA();
 
    //用法2 : 直接写函数名,不能带括号也不能带引号,适合没有参数的函数
    function funB(){
        log('funB...');
        setTimeout(funB, 1000);
    }
    funB();
 
     //用法3 : 通过调用匿名函数来执行,适合有带参数的函数
    function funC(v){
        log('funC...'+v);
        setTimeout(function(){funC(v+1)}, 1000);
    }
    funC(1);
 
    //用法4 : 通过在jQuery命名空间上增加函数,适用面更广
    $.extend({
            funD:function(v){
                log('funD...'+v);
                setTimeout("$.funD("+(v+1)+")",1000);
            }
      });
      $.funD(100);
 });

用法2和用法3的区别很明显, 但用法3和用法4的区别在哪里呢?为什么说用法4比用法3适用面更广呢?通过下面这个例子可以很直观的明白二者的区别:

jQuery(document).ready(function($){
    //用法3 : 通过调用匿名函数来执行,适合有带参数的函数
    function funC(v){
        log('funC...'+v);
        setTimeout(function(){funC(v+1)}, 1000);
    }
 
    //用法4 : 通过在jQuery命名空间上增加函数,调用起来更方便
    $.extend({
        funD:function(v){
            log('funD...'+v);
            setTimeout("$.funD("+(v+1)+")",1000);
        }
    });
});
 
jQuery(document).ready(function($){
    //funC(1);   //去掉注释后执行这一句时会报错
    $.funD(100); //这一句是正常的, 明白两者之间的区别了吧
});

另外 setInterval 也同样适合上面所说的4种方法.

jQuery的`setTimeout`函数用于延迟执行一段代码或调用一个函数。它允许你在指定的时间后运行一个回调函数。这里有几种使用方式: 1. **标准语法**[^1]: ```javascript // 使用匿名函数和延迟时间 var timeoutID = jQuery.setTimeout(function() { console.log('This will be displayed after the specified delay.'); }, 2000); // 或者传递一个自定义函数 function sayHello() { alert('Hello!'); } var timeoutID = jQuery.setTimeout(sayHello, 5000); ``` 2. **箭头函数支持**: ```javascript // 使用箭头函数 const introduce = (name) => { console.log(`Introducing ${name} in 2 seconds.`); }; var timeoutID = jQuery.setTimeout(introduce, 2000, 'John Doe'); ``` 3. **绑定上下文**: 当需要保持函数内部`this`指向特定的对象时,可以使用`.bind()`方法: ```javascript var person = { introduce: function() { console.log(this.name + ' says hello.'); } }; var timeoutID = jQuery.setTimeout(person.introduce.bind(person), 1000, 'Alice'); ``` 4. **与clearTimeout配合**: `setTimeout`返回一个ID,你可以用来取消已设置的定时器: ```javascript var timer = jQuery.setTimeout(myFunction, 5000); if (/* some condition */) { clearTimeout(timer); } ``` 注意,尽管`setTimeout`属于jQuery库的一部分,但通常建议直接使用原生JavaScript的`setTimeout`,因为这样能避免额外的库依赖。在jQuery中,`setTimeout`的用法与其他库可能略有不同,特别是当涉及性能优化和避免DOM操作时。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值