0

ここにはたくさんのコードがありますが、問題は下部のforループに関係しています。

var dbo = openDatabase('xxx','1.0','myDatabase', 1048576);
var DropTableDeferred = new $.Deferred();
var CreateTableDeferred = new $.Deferred();
var InsertDeferred = new $.Deferred();
var SelectDeferred = new $.Deferred();
dbo.transaction(function(myTrans) {
    myTrans.executeSql(
        'drop table myTable;'
        ,[]
        ,DropTableDeferred.resolve()
    );
});
DropTableDeferred.done(function() {
    dbo.transaction(function(myTrans) {
        myTrans.executeSql(
            'CREATE TABLE IF NOT EXISTS myTable' 
            + '(xxxID Integer NOT NULL PRIMARY KEY'
            + ',xxxName Varchar(128)'
            + ');'
            ,[]
            ,CreateTableDeferred.resolve()
        );
    });
});
CreateTableDeferred.done(function() {
    dbo.transaction(function(myTrans) {
        myTrans.executeSql("INSERT INTO myTable(xxxID,xxxName) VALUES(1,'A')");
        myTrans.executeSql("INSERT INTO myTable(xxxID,xxxName) VALUES(2,'B')");
        myTrans.executeSql(
            "INSERT INTO myTable(xxxID,xxxName) VALUES(3,'C')",
            [],
            InsertDeferred.resolve()
        );
    });
});

InsertDeferred.done(function() {
    dbo.transaction(function(myTrans) {
        myTrans.executeSql(
            'SELECT * FROM myTable',
            [], 
            function(tx, result) {
                SelectDeferred.resolve(result);
            }
        );
    });
});

SelectDeferred.done(function(result) {
    var X = $('#result-template').html();
    var template = Handlebars.compile(X);
    var data = [];

    for(var i=0;i < result.rows.length; i++) {
        data.push(result.rows.item(i));
    }
    $('ul').append(template(data));
});

Q:template(data)を呼び出すためにデータ配列を作成する必要がありますか、それとも結果変数を直接渡すことができますか?

そして、「結果変数」とは、result.rows、result.rows.item、またはその他の組み合わせを意味します。

4

2 に答える 2

1

私見はできますが、実を言うと、質問を投稿するよりも、試してみるのに時間がかからなかったでしょう。ちょうど試して:

$('ul').append(template(result.rows));
于 2012-05-01T19:48:46.237 に答える
1

はい、値は私のhtml&javascriptのみのプロジェクトで直接渡されました。以下のコードでは、SQLの結果を取得し、ドロップダウンボックスのオプションを入力します。

    function fillLectureFromDB(tx) {
        tx.executeSql('SELECT * FROM LECTURE', [], successFill, errorFill);
    }
    function successFill(tx, results) {
        var len = results.rows.length;
        for (var i=0; i<len; i++){
            var elOptNew = document.createElement('option');
            elOptNew.text = results.rows.item(i).code;
            elOptNew.value = results.rows.item(i).code;
            var elSel = document.getElementById('slExCode');
            elSel.add(elOptNew, null);  
        }
    }
于 2012-05-01T19:49:20.493 に答える