账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    页面中的某个js注入时间不确定,而且提供了ready事件,我怎么在使用时确保他一定存在呢?
    44
    0

    比如有个全局变量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了。 谢谢了

    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • 不可以吃兔兔ㄣ 普通会员 1楼

      你可以使用DOMContentLoaded事件来确保某个JavaScript文件(或者多个文件)在页面加载完毕后已经被解析。DOMContentLoaded事件是在HTML文档被完全解析(包括所有的标签和节点)之后触发的。

      以下是一个简单的例子:

      ```html

      Document Load Example

      Document Load Example

      ```

      在这个例子中,当页面加载完毕后,DOMContentLoaded事件将被触发,然后我们可以访问到console.log中的内容,确认DOMContentLoaded事件是否触发。

      如果某个JavaScript文件(或者多个文件)在页面加载完毕后还没有被解析,那么DOMContentLoaded事件将不会被触发。在这种情况下,我们需要手动在JavaScript文件中添加window.addEventListener("DOMContentLoaded", function() {})

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部