比如有个全局变量STS
,这个变量所在的js文件是客户端注入到我们的页面里的,注入到页面后并初始化完成后会执行一个ready
事件。可是这个js文件的注入时间却无法保证,我们只能每次都检测一下,如果存在则直接使用,不存在的话,需要ready一下:
if( window.STS ){
load();
}else{
document.addEventListener('stsready', function(){
load();
})
}
可是我在使用这个变量里的方法时,总不能每次都这样写一遍检测STS
是否存在吧:
const tip = function( msg ){
STS.showTip(msg);
}
if( window.STS ){
tip( Date.now() );
}else{
document.addEventListener('stsready', function(){
tip( Date.now() );
})
}
有没有通过Promise
或者什么方式来包装一下,每次使用时都能保证全局变量存在,如果不存在就先暂时存储起来,等ready
事件执行后,再一并执行呢?
function BB(){
}
var bb = new BB();
bb.invoke('showTip', Date.now());
比如这样的,通过BB包装一下,然后后面我直接使用即可,这样我就能调用到STS中的showTip
方法,不用再每次都检测STS
了。 谢谢了
使用Promise编写一个ready函数,然后调用一下即可: