jquery如何接管ready事件?-问答-阿里云开发者社区-阿里云

开发者社区> 小旋风柴进> 正文

jquery如何接管ready事件?

2016-03-26 11:06:10 1546 1

我要做了某些事情(例如等待某个浏览器插件就绪)后才触发ready事件,请问如何实现?

取消 提交回答
全部回答(1)
  • 小旋风柴进
    2019-07-17 19:15:48

    jquery中已经提供了这种延迟触发ready的方式。

    我们先来看一个正常顺序执行的例子:

    setTimeout(function(){
        console.log('timeout');
    }, 500);
    
    $(function(){
        console.log('ready');
    })
    这个例子中,肯定会首先输出ready,然后再输出timeout。
    
    不过jquery提供了一个$.holdReady()方法来延迟ready的触发。
    
    setTimeout(function(){
        console.log('timeout');
    
        // 不用再hold住ready方法了,释放,则现在触发ready方法
        $.holdReady(false);
    }, 500);
    
    // 先把readyhold住,不让ready触发,$.holdReady(true)没有位置的限制,可以放到最上面
    $.holdReady(true);
    $(function(){
        console.log('ready');
    })
    不过如果有多个组件(比如10个的话)都加载完成再触发ready的话,那是不是要写10个$.holdReady(true)呢。其实不用的,可以用$.readyWait来操作。把$.readyWait的值设置为限制的次数+1就行。如:
    
    setTimeout(function(){
        console.log('timeout0');
        $.holdReady(false);
    }, 500);
    setTimeout(function(){
        console.log('timeout1');
        $.holdReady(false);
    }, 500);
    setTimeout(function(){
        console.log('timeout2');
        $.holdReady(false);
    }, 500);
    
    $.readyWait = 4;
    $(function(){
        console.log('ready');
    })

    这样就能在三个setTimeout都执行完成后再执行ready。其实$.holdReady()在源码也是操作的$.readyWait的值,$.holdReady(true)让$.readyWait的值+1,$.holdReady(false)让$.readyWait的值-1,当$.readyWait的值为1时就触发ready。$.readyWait的默认值是1,所以默认会直接触发ready的。

    不过,这样直接使用$.readyWait不是很好,因为$.readyWait是对内使用的,对外提供的方法就是$.holdReady()。因此,若没有特别的情况,使用$.holdReady()就能控制ready的执行了。

    0 0
相关问答

11

回答

在阿里云上安装和运行Node.js全功略

ycwong 2013-09-18 15:17:30 64018浏览量 回答数 11

19

回答

【分享】如何提高网站的打开速度?

enj0y 2012-11-17 14:35:22 56720浏览量 回答数 19

145

回答

【新手入门】云服务器linux使用手册

fanyue88888 2012-11-26 17:14:18 157070浏览量 回答数 145

28

回答

钉钉开放平台“常见问题常见问题常见问题“重要请关注

竹梅 2015-12-03 00:39:14 92862浏览量 回答数 28

22

回答

爬虫数据管理【问答合集】

我是管理员 2018-08-10 16:37:41 146769浏览量 回答数 22

31

回答

[@倚贤][¥20]刚学完html/css/js的新手学习servlet、jsp需要注意哪些问题?

弗洛伊德6 2018-10-27 21:52:43 145607浏览量 回答数 31

23

回答

【云服务器分享】网站访问速度快才是硬道理

dreamdoo 2012-10-15 10:15:02 85181浏览量 回答数 23

13

回答

【云服务器分享】如何节省网站流量

dreamdoo 2012-10-15 10:36:09 80111浏览量 回答数 13

14

回答

对象存储oss【问答合集】

我是管理员 2018-08-03 14:54:02 67361浏览量 回答数 14

2

回答

Nginx—owncloud安装记事

寒喵 2014-06-07 23:24:41 48515浏览量 回答数 2
2728
文章
6591
问答
推荐问答
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载