我有以下函数从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);
}
});
}
答案 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){在这里做某事......})来监听该事件。