Javascript 我是否需要在cordova/phonegap项目中的所有html文件中添加app.initialize()
我正在做一个phonegap/cordova项目。我使用命令行创建了一个框架项目,正如创建一个新的android/phonegap项目所建议的那样 在创建的index.html文件中有一段代码Javascript 我是否需要在cordova/phonegap项目中的所有html文件中添加app.initialize(),javascript,android,html,cordova,jquery-mobile,Javascript,Android,Html,Cordova,Jquery Mobile,我正在做一个phonegap/cordova项目。我使用命令行创建了一个框架项目,正如创建一个新的android/phonegap项目所建议的那样 在创建的index.html文件中有一段代码app.initialize(),该代码来自一个名为index.js的文件 我的问题是,我是否必须在我所有的html文件中都包含这段代码,因为我将使用jQueryMobile做前端,我可能需要几个html文件 var app = { // Application Constructor in
app.initialize()
,该代码来自一个名为index.js的文件
我的问题是,我是否必须在我所有的html文件中都包含这段代码,因为我将使用jQueryMobile做前端,我可能需要几个html文件
var app = {
// Application Constructor
initialize: function() {
this.bindEvents();
},
// Bind Event Listeners
//
// Bind any events that are required on startup. Common events are:
// 'load', 'deviceready', 'offline', and 'online'.
bindEvents: function() {
document.addEventListener('deviceready', this.onDeviceReady, false);
},
// deviceready Event Handler
//
// The scope of 'this' is the event. In order to call the 'receivedEvent'
// function, we must explicity call 'app.receivedEvent(...);'
onDeviceReady: function() {
app.receivedEvent('deviceready');
},
// Update DOM on a Received Event
receivedEvent: function(id) {
var parentElement = document.getElementById(id);
var listeningElement = parentElement.querySelector('.listening');
var receivedElement = parentElement.querySelector('.received');
listeningElement.setAttribute('style', 'display:none;');
receivedElement.setAttribute('style', 'display:block;');
console.log('Received Event: ' + id);
}
};
由于所有页面都是通过Ajax调用调用的,所以理论上,您不需要在所有页面中添加该行。但在某些情况下,您可能需要添加它,例如,如果某个特定页面可能不是通过ajax调用调用的,或者某个用户出于某种奇怪的原因登录到该页面,而不是您的索引页面。如果您不打算使用ajax调用新页面(也就是说,只需像打开新页面一样打开new.html)然后,是的,调用all。阅读一本书,它说当检测到一个页面的外部链接(托管在同一服务器/域上)时,jQueryMobile将使用Ajax调用该页面。我已经试过了,另一个页面工作得很顺利,我只需要确定它是否应该这样工作。