nodejs函数中的回调 - 新手查询

时间:2015-12-12 15:52:43

标签: javascript node.js callback

我有以下函数从html页面中提取一些变量并通过正常工作的i / o发布它们 - 但我想添加一个回调以确保我能找出这个函数是否已完全完成。 / p>

请告知我如何才能完全为此目的添加回调 - 因为我没有其他任何回调需求。

function RunScrapingPositions() {
    status = false;
    myhttp.get('https://example.com/PB.jsp',
    function (_html) {
            if (_html && _html.length > 10) {          
            news.positions = {};
            $ = cheerio.load(_html);

            $('tr[id^="TR"]').each(function () {
                  status = true;
                  var symbol = $('td:nth-child(3)', this).text().trim();
                  var objob = {
                     'NQ': parseInt($('td:nth-child(11)', this).text().trim()),
                              };

                  var post = {
                        'symbol': symbol,
                        'nq': objob.NQ
                            };


            connection.query('INSERT INTO NP SET ?', post, function (err,result){
            if (err) 
            {console.log("NP sql insert error : " +symbol);}
            else {
                console.log("Posn - Step 3B - Position data inserted into NP Table : " +symbol);
                 }
        });




                var objstock = news.analysis[symbol];

                if (typeof objstock!='undefined') {
                    objstock.NQ = objob.NQ;
                    news.positions[symbol] = objob;
                    news.analysis[symbol] = objstock;

                if (status) {
                     console.log('Posn - Step 4 - Positions data pushed to page')
                     io.emit('news', news);

                            }
               }
                 else           
               {
               console.log('Posn - Step 4A - Position symbol not found');
               } 
            });


            if (timerPositions) {
                clearTimeout(timerPositions);
            }
            console.log('Posn - Step 5 - setTimer RunScrapingPositions:' + config.DelayExtractPositions);
            timerPositions = setTimeout(RunScrapingPositions, config.DelayExtractPositions);

        }

    });
}

2 个答案:

答案 0 :(得分:0)

您可以通过以下步骤实现回调:

接受回调函数作为参数:

function RunScrapingPositions(callbackDone) {

然后,在你调用它的地方,传递该函数。您可以使用bind。如果你有条件完成所有工作,请将其命名为:

function RunScrapingPositions(callbackDone) {
    status = false;
    myhttp.get('https://example.com/PB.jsp', function (_html) {
        if (_html && _html.length > 10) {
            // ... 

            // pass the callback function on to the deferred call:
            timerPositions = setTimeout(
                    RunScrapingPositions.bind(null, callbackDone),
                    config.DelayExtractPositions
            );
        } else {
            // all is done, call the callback function:
            callbackDone();
        }
    });
}

答案 1 :(得分:0)

您还可以使用jQuery的自定义事件工具,$(document).trigger({eventName},obj或参数列表)来触发"事件"。您可以编写代码来通过$(document).on({eventName},function(someArgsThatYouPass){在这里做某事......})来监听该事件。