0

Worklight を使用して、ローカル ストレージを使用するアプリケーションを構築しています。createCollection()common/js/myApp.js で関数を宣言しました。

ただし、ブラウザー シミュレーターで実行すると、コンソールの JavaScript に次のように表示されます。

キャッチされていない TypeError: 未定義のメソッド 'initCollection' を呼び出せません。

助言がありますか?

私のJavaScript:

function wlCommonInit(){
// Common initialization code goes here
}

// inizializzazione json
window.onload = createCollection;

var isOpen = true;
var menuboxw = $("#menubox").css("width");
$("#contentbox").css("left",menuboxw);
var headerh = $("#header").height();
$("#contentbox").css("top", headerh);
$("#menu_btn").click(function(){menu()});

// apertura/chiusura menu principale
function menu() {
if(isOpen){
    $('#contentbox').animate({ left: -5 }, 1);
    $("#menubox").css("visibility", "hidden");
    isOpen = false;
}
else{
    $('#contentbox').animate({ left: menuboxw }, 1);
    $("#menubox").css("visibility", "visible");
    isOpen = true;
}
}

// creazione collection 'canti' e 'categorie'
function createCollection(){

WL.Logger.debug("Called createCollection");
WL.SimpleDialog.show("Message", "createCollection called", [{text: "Ok"}]);

var collectionCanti = "canti";
var searchFieldsCanti = {titolo: "string", autore: "string", id_categoria: "string", testo: "string"};
var collectionCategorie = "categorie";
var searchFieldsCategorie = {titolo: "string", attiva: "number"};

var success = function(data){
            logMessage("Collection created successfully " + data);
};

var failure = function(data){
            logMessage("Collection doesn't created " + data);
};

var options = {onSuccess: success, onFailure: failure};

canti = WL.JSONStore.initCollection(collectionCanti, searchFieldsCanti, options);
categorie = WL.JSONStore.initCollection(collectionCategorie, searchFieldsCategorie, options);

}
4

1 に答える 1

1

以下をせよ:

  1. 削除するwindow.onload = createCollection;
  2. createCollection();内側に追加wlCommonInit()

ところで、それlogMessageはエラーを生成します。おそらく変更するWL.Logger.debug必要があります(コードで既に使用しています...)。


IBM Worklight Getting Started トレーニング資料を参照してください。スキップなし。

于 2013-10-04T11:24:13.817 に答える