PHP中文网2017-07-05 11:09:52
我利用了 dom 節點的 children 屬性 來遍歷和遞歸
遞歸套路是: 回傳 (1 + 子節點們深度的最大值)
// map(e => e + 1)([0, 1, 2])
// => 1, 2, 3
// 类似于数组的map方法 不过这里柯里化了
var map = cb => arr => Array.prototype.map.call(arr, cb);
// 取数组最大值
// max([0, 1, 2])
// => 2
var max = arr => arr.reduce((acc, cur) => {
if (cur >= acc) return cur;
else return acc;
}, arr[0]);
// 递归函数
var nextChildren = node => {
// 基准条件
if (node.children.length === 0) return 1;
else {
// 求子节点们的长度 并取最大值
var deeps = map(nextChildren)(node.children);
return 1 + max(deeps);
}
}
// 计算
var $body = document.getElementsByTagName('body')[0];
var deep = nextChildren($body);
console.log(deep);