deviceready事件
来源:互联网 发布:可以截取音乐的软件 编辑:程序博客网 时间:2024/06/05 21:13
Cordova框架中第一个应该掌握的就是这个deviceready事件。采用Cordova开发的应用在运行的时候,Cordova提供的通过HTML5调用Native功能并不是立即就能使用的,Cordova框架在读入HTML5代码之后,要进行HTML5和Native建立桥接,在未能完成这个桥接的初始的情况下,是不能调用Native功能的。在Cordova框架中,当这个桥接的初始化完成后,会调用他自身特有的事件,即deviceready事件。
document.addEventListener('deviceready', function () { console.log('Device is Ready!'); // ....your code}, false);需要注意的是,deviceready事件是在每回读入HTML的时候都会被调用,而不只是应用启动时调用。
除了deviceready事件以外,Cordova应用在内部读取HTML代码的时候还会调用一些其他的事件。但这些并不是Cordova框架提供的事件,而是嵌入的Webview的浏览器Render引擎提供的。
DOMContentLoaded事件
页面的DOM内容加载完成后即触发,而无需等待其他资源(CSS、JS)的加载。
load事件
在DOMContentLoaded事件之后,其他资源加载完成后触发。
所以,其实调用的顺序是:DOMContentLoaded -> load -> deviceready
deviceready事件一定是在load事件之后,所以load事件的执行速度会影响到deviceready事件的调用。把一些不必要的资源可以在deviceready事件之后调用从而提高执行速度。
document.addEventListener('DOMContentLoaded', function () { console.log('DOMContentLoaded OK!');}, false);window.addEventListener('load', function () { console.log('load OK!');}, false);document.addEventListener('deviceready', function () { console.log('deviceready OK!');}, false);
需要注意的是,在Cordova的app中如果js执行失败,前台不会有任何提示(后台会出log),所以很多时候点击都没有任何反应,那说明JS执行出错了,把以下代码加到index.html中,当应用发生JS错误的时候,会调用window的onerror方法从而显示错误信息,从而捕获JavaScript的Error提示用户。
window.onerror = function(msg, url, line) { var idx = url.lastIndexOf("/"); if(idx > -1) { url = url.substring(idx+1); } alert("ERROR in " + url + " (line #" + line + "): " + msg); return false;};
1 0
- deviceready事件
- deviceready事件
- phonegap中的deviceready事件
- Phonegap的deviceready事件
- Phonegap的deviceready事件
- Cordova 3.x 基础 -- deviceready事件
- Apache Cordova 3.x -- deviceready事件
- Cordova 3.x 基础(4) -- deviceready事件
- Cordova 3.x 基础(4) -- deviceready事件
- cordova ,ionic 中cordova.js 提示deviceready has not fired after 5 seconds
- phonegap android开发中出现deviceready event not fired和Channel not fired的问题的解决办法
- 事件
- 事件
- 事件
- 事件
- 事件
- 事件
- 事件
- Lucene查询结果高亮
- ZOJ - 1048 Financial Management
- 第九周上机实践项目-阅读项目-3
- Android自定义控件之继承ViewGroup创建新容器(四)
- 阿里、腾讯、美图等公司笔试心得【web前端岗】
- deviceready事件
- arduleader
- Laxcus大数据管理系统2.0(13)- 总结
- Java千百问_05面向对象(011)_引用传递和值传递有什么区别
- acm_1003_pie
- Laxcus大数据管理系统2.0(14)- 后记
- [C++]类型转换
- Android:使用Gson解析复杂的JSON数据
- JSTL(c标签)与Struts2(s标签)标签的常用功能对比