我要做了某些事情(例如等待某个浏览器插件就绪)后才触发ready事件,请问如何实现?
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的执行了。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。