关于HTML5+ API plusready的兼容问题

2022-07-27,,

android平台提前注入5+ api,支持在plusready事件前调用

在5+ runtime环境中,通常情况下需要html页面解析完成后才会注入5+ api,执行的顺序为:

1. 加载html页面

2. 解析html页面(下载script/link等节点引用的资源,如js/css文件)

3. 触发domcontentloaded事件

4. 注入5+ api

5. 触发plusready事件

这样导致5+ api生效时间比较延后,在html中引用js执行之后才能调用5+ api,通常采用以下代码调用5+ api:

document.addeventlistener('plusready',function () { 
        // 在这里调用5+ api 
        // 如获取设备唯一标识 plus.device.uuid
},false); 

但是在新版本中,将支持提前注入5+ api,可以在plusready事件触发之前调用5+ api,提前引入节点:

<script src="html5plus://ready"></script>

兼容写法:

if(window.plus){ 
    // 在这里调用5+ api 
}else{// 兼容老版本的plusready事件 
    document.addeventlistener('plusready',function () { 
        // 在这里调用5+ api 
    },false); 
}

注意
1. 仅仅是提前注入5+ api,并不会提前触发plusready事件(仅步骤4提前操作了)
2. android3.0及以上平台才支持提前注入,android2.*版本无法提前注入
3. 在流应用环境中的wap2app会自动提前注入(第一次引用网络js时注入),不需要添加<script src="html5plus://ready"/>节点

到此这篇关于html5+ api plusready的兼容问题的文章就介绍到这了,更多相关html5 api plusready 兼容内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!

《关于HTML5+ API plusready的兼容问题.doc》

下载本文的Word格式文档,以方便收藏与打印。