0

以下のコードは、いくつかの値をローカルストレージに保存する必要があるフォーム用であり、ブラウザーで機能するようになっていますが、これをxcode / cordovaにロードすると、関数が起動しません。デバッグを試みたため、多くのアラートをライブビューでDWCS6で試しましたが、役に立たず、実行できないようです。エラーを見つけていただけますか?

この関数saveSpanning()にはifループがあり、if-then-elseループから抜けると、xcodeシミュレーターでは続行されません。ブラウザでは続行します。

更新:機能:値を生成するスライダーがあります。この値は、他の2つの値(JavaScriptによって生成される)と一緒にローカルストレージに保存する必要があります。つまり、日付とレコード数です。つまり、全部で3つの値です。

スクリプトはjquerymobileを使用して実行され、この関数を開始するボタンが機能します。document.ready代わりonBodyLoadに使用します。基本的には機能しますがsaveSpanning、phonegap / ios/xcodeシミュレーターまたはデバイスでは関数はそれ以上進みません。

function saveSpanning() {
    alert("saveSpanning gestart!");
    var inputSpanning = document.getElementById("valSliderSpanning").value;
    alert("input spanning = " + inputSpanning);

    //For Time
    var mes_time = document.getElementById("tijdSpanning").value;
    var mestimearr = mes_time.split(":");
    //For Date
    var mes_date = document.getElementById("datumSpanning").value;
    var mesdatearr = mes_date.split("-");
    var d = new Date();
    var curr_date = d.getDate();
    var curr_month = d.getMonth() + 1; //Months are zero based
    var curr_year = d.getFullYear();
    var curr_hours = d.getHours();
    var curr_min = d.getMinutes();
    var curr_sec = d.getSeconds();
    //newDate = curr_year + "/" + curr_month + "/" + curr_date + " " + curr_hours + ":" + curr_min + ":" + curr_sec
    // origienel opmaak datum newDate = mesdatearr[0] + "/" + mesdatearr[1] + "/" + mesdatearr[2] + " " + mestimearr[0] + ":" + mestimearr[1] + ":00";
    newDate = mesdatearr[0] + "/" + mesdatearr[1] + "/" + mesdatearr[2];

    alert("deze datum wordt opgelsage: " + newDate);

    //var itemId = newDate.getTime(); //creates a unique id with the milliseconds since January 1, 1970
    var itemId = "spanningKey";
    var values = new Array();
    values.push(newDate); //push each value into our values array
    values.push(inputSpanning); //push each value into our values array
    //alert(inputSpanning);

    var spanningCountVal = localStorage.getItem('spanning_count');

    //alert(spanningCountVal);
    if (spanningCountVal == null) {
        spanningCountVal = 1;

        alert("spanningCountVal was null, en wordt dus nu 1: " + spanningCountVal);

    }
    else {
        spanningCount = parseInt(spanningCountVal) + 1;
        alert("zit nu in de else loop: " + spanningCount);

    }

    alert("uit de ifthenelseloop, spanningCount = " + spanningCount);

    itemId = itemId + '-rec-' + spanningCount;
    alert("itemid: " + itemId);
    alert("spanningCountVal: " + spanningCount);


    localStorage.setItem("spanning_count", spanningCount); //store the item in the database
    localStorage.setItem(itemId, values.join("|")); //store the item in the database
    alert("Successfully Saved.");
}


$(document).ready(function() {

    $("#button").click(function() {
        alert("hallo functie");
    });

    $("p").text("The DOM is now loaded and can be manipulated.");



    $('#button2').click(function() {
        alert('Button has been clicked');
    });
    $('#knopje').click(function() {
        saveSpanning();
    });
});​
4

1 に答える 1

1

document.readyすべてのDOM要素がロードされ、アクセス可能になったときに呼び出されます。ブラウザでは、これは通常、DOMの準備ができている必要があるコードの実行を開始する良い機会です。

document.readyただし、Phonegap / Cordovaでは、デバッグコンソールへの接続など、イベントが発生した後に実行されるいくつかの手順があります。

代わりに、 phonegap / cordovaが完全にロードされ、実行の準備ができたことをデバイスレディイベントが認識するのを待つ必要があります。内部に、メソッド$(document).on('ready')を起動するイベントリスナーを追加する必要がありdevicereadyます。

于 2012-12-01T15:19:16.543 に答える