Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/453.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 我是否需要在cordova/phonegap项目中的所有html文件中添加app.initialize()_Javascript_Android_Html_Cordova_Jquery Mobile - Fatal编程技术网

Javascript 我是否需要在cordova/phonegap项目中的所有html文件中添加app.initialize()

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

我正在做一个phonegap/cordova项目。我使用命令行创建了一个框架项目,正如创建一个新的android/phonegap项目所建议的那样

在创建的index.html文件中有一段代码
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调用该页面。我已经试过了,另一个页面工作得很顺利,我只需要确定它是否应该这样工作。