求解释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 个回答

    你直接跟踪一下函数的运行,比如当i=3是,f(3)--3-->f(2)--2-->f(1)--1-->f(0)--0-->f(-1),当i=-1,return跳出函数.执行console.log返回0,1,2,3

      相似问题
      推荐文章