2

私は初めてasync.jsを使用していますが、関数配列を別々の関数に分離したいと思います。私は持っています:

作業コード

    async.waterfall([
        function(callback)
        {
            var querySuccess = function (tx, result)
            {
                callback(null, result.rows.item(0).EventImportTime || "");
            };

            var queryError = function (tx, e)
            {
                callback("Query Error")
            };

            database.open();
            database.query("SELECT EventImportTime FROM Contact WHERE Contact.Id = ?", [contactId], querySuccess, queryError);
        },
        function(lastImportTime, callback)
        {
            var url = "";
            url += 'MobileGetvents.aspx?';
            url += '&LastImportTime=';
            url +=  lastImportTime;
            url += '&Format=JSON';

            callback(null, url)
        },
    ],
    function(err, result)
    {
        if (err)
            console.log("Error Happened");
        else 
        {
            console.log(result);
            getJSON(result, callback, 

errorCallback)
            }
        })

が欲しいです

async.waterfall([
            getLastImportTime(callback) ,
            buildUrl(lastImportTime, callback),
        ],
        //callback
);

ただし、このコードを実行すると、常に

Uncaught ReferenceError:lastImportTimeが定義されていません

4

1 に答える 1

5

代わりにこれが必要だと思います。

var getLastImportTime = function(callback) { };
var buildUrl = function(lastImportTime, callback) { };

async.waterfall([
            getLastImportTime,
            buildUrl,
        ],
        //callback
);
于 2012-05-15T11:28:16.343 に答える