如何递归地调用这个函数
How to call this function recursively?
我试图想出一个基本的网络爬虫。堆栈跟踪将来要访问的所有url。
在堆栈为空之前,想要获得在网页中使用的所有href的列表。试着用论据。Calee但是它返回:
JavaScriptRangeError: Maximum call stack size exceeded
"checkStack": function(test) {
//check if the stack is empty
if (!stack.isEmpty()) {
var newAddress = stack.pop();
console.log("trying to navigate to: ", newAddress);
return test.remote.get(newAddress)
.setFindTimeout(240000)
//.sleep(4000)
.findAllByTagName("a")
.getAttribute("href")
.then(function(hrefs) {
console.log("got hrefs: " + hrefs.length);
assert.isArray(hrefs, 'Links not an array');
checkAddressValidity(hrefs, 0);
})
.then(function() {
//call checkStack recursively
checkStack(test);
}.bind(test));
}
},
...
在命令链(或任何承诺链,实际上!)中执行递归的简单方法是将堆栈保持在闭包中,然后作为承诺回调调用递归完成工作的方法,直到堆栈耗尽。一旦堆栈被解析,undefined
将由next
返回,而不是另一个承诺,这标志着递归的结束:
checkStack: function (test) {
var remote = test.remote;
var stack = [];
function next() {
var newAddress = stack.pop();
if (newAddress) {
return remote.get(newAddress)
.findAllByTagName('a')
.getAttribute('href')
.then(function (hrefs) {
// do whatever
})
.then(next);
}
}
return next();
}
相关文章:
- 如何从模块链中调用函数.导出到节点中
- 调用函数内部的函数
- 在javascript中调用c函数
- DropDownListFor赢得't在更改时调用函数
- Javascript页面调用函数
- 在动画结束之前调用函数
- 允许父窗口在其不同域的子iframe上调用函数
- 运行Infinite Scroll后调用函数时出现问题
- JavaScript:在调用函数的文本输入上按enter键
- 使用大括号和不使用bracs调用函数的区别
- javascript在事件上调用函数
- 从index.html调用函数,该函数无限循环
- 从带参数的字符串变量调用函数中的函数
- 为什么 JS 不在滚动时调用函数
- 是否可以在不更改上下文的情况下调用函数.apply
- 如何在ES6类中使用参数调用函数
- AngularJS:调用函数时编号不更新
- JavaScript中的立即调用函数表达式(IIFE)-传递jQuery
- 在JavaScript中调用函数时自定义此选项
- 调用函数中声明的变量