求解释js递归

function foo(i) {
  if (i < 0)
  return;
  console.log('begin:' + i);
  foo(i - 1);
  console.log('end:' + i);
}
foo(3);

// begin:3
// begin:2
// begin:1
// begin:0
// end:0
// end:1
// end:2
// end:3

求帮忙解释这段代码的流程,本人太菜所以希望大神详细点。

阅读 6.9k
评论
    7 个回答
    • 590

    这是函数栈,如果不清楚栈,先去了解栈。然后想象一下,每次去把执行的函数压栈,执行完毕再出栈。即可。

      相似问题
      推荐文章