一道优雅面试题分析js中fn()和return fn()的区别


Posted in Javascript onJuly 05, 2016

在js中,经常会遇到在函数里调用其它函数的情况,这时候会有 fn() 这种调用方式,还有一种是 return fn() 这种调用方式,一些初学者经常会被这两种方式给绕晕了。这里用一个优雅的面试题来分析一下两种方式的不同之处。 

var i = 0;
function fn(){
 i++;
 if(i < 10){
 fn();
 }else{
 return i;
 }
}

var result = fn();
console.log(result);

这是一道隐藏了坑的面试题,看似很简单,大部分人可能想都不想就答出了10。而实际上运行可知打印出来的是 undefined。这道陷阱题很直观的体现出了前面所说的问题,当我们将执行fn的那一行修改为: 

var i = 0;
function fn(){
 i++;
 if(i < 10){
 return fn();
 }else{
 return i;
 }
}

var result = fn();
console.log(result);

这时,会发现打印出来的结果终于不负众望的是 10 了。

为什么这里加不加return区别会这么大? 

这里的主要原因很简单,JavaScript的函数都是有默认返回值的,如果函数结尾不写return,会默认返回undefined,这就是为什么在chrome的console控制台里,写代码经常下面会出现一行undefined的原因。 

再仔细看看这个例子,当i自增到9的时候,也就是倒数第二次递归调用fn的那一次,如果没有return,这一次执行完fn,会默认return undefined,而不会继续下一次递归了。当加上了 return,在这里则会继续最后一次递归,即i=10的时候,跳入else里面返回得到正确的10。 

说到这里,可以引申出一个更为经典的例子,著名的二分查找法: 

var mid = Math.floor((arr.length - 1) / 2);

function search(n, mid) {
 if (n > arr[mid]) {
 mid = Math.floor((mid + arr.length) / 2);
 return search(n, mid);
 } else if (n < arr[mid]) {
 mid = Math.floor((mid - 1) / 2);
 return search(n, mid);
 } else {
 return mid;
 }
}

var index = search(n, mid);
console.log(index);

二分查找法也是需要多次递归调用,很多新手在第一次实现这个算法的时候经常会犯的一个错误就是忘记在递归的函数前加上return,最后导致返回结果是undefined,这里的道理也和前面是类似的,不加return,会导致递归后,直接返回undefined,不会继续下一次递归。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery实现textarea输入字符控制(仿微博输入控制字符)
Apr 26 Javascript
鼠标经过显示二级菜单js特效
Aug 13 Javascript
Node.js与PHP、Python的字符处理性能对比
Jul 06 Javascript
jQuery级联操作绑定事件实例
Sep 02 Javascript
jQuery中animate动画第二次点击事件没反应
May 07 Javascript
jQuery插件FusionCharts绘制的2D条状图效果【附demo源码】
May 13 jQuery
jQuery Autocomplete简介_动力节点Java学院整理
Jul 17 jQuery
在Swiper内如何制作CSS3动画效果示例代码
Dec 07 Javascript
浅谈JavaScript 代码整洁之道
Oct 23 Javascript
vue微信分享出来的链接点开是首页问题的解决方法
Nov 28 Javascript
vue路由前进后退动画效果的实现代码
Dec 10 Javascript
js+css3实现炫酷时钟
Aug 18 Javascript
JS实现环形进度条(从0到100%)效果
Jul 05 #Javascript
JQuery组件基于Bootstrap的DropDownList(完整版)
Jul 05 #Javascript
结合代码图文讲解JavaScript中的作用域与作用域链
Jul 05 #Javascript
jQuery的Each比JS原生for循环性能慢很多的原因
Jul 05 #Javascript
Node.js实现文件上传
Jul 05 #Javascript
JavaScript数组方法大全(推荐)
Jul 05 #Javascript
JS与HTML结合使用marquee标签实现无缝滚动效果代码
Jul 05 #Javascript
You might like
基于mysql的论坛(4)
2006/10/09 PHP
php读取mssql的ntext字段返回值为空的解决方法
2014/12/30 PHP
js实现的日期操作类DateTime函数代码
2010/03/16 Javascript
基于jquery实现的定时显示与隐藏div广告的实现代码
2013/08/22 Javascript
jquery带动画效果幻灯片特效代码
2015/08/27 Javascript
原生JS实现首页进度加载动画
2016/09/14 Javascript
node.js平台下的mysql数据库配置及连接
2017/03/31 Javascript
jQuery实现多张图片上传预览(不经过后端处理)
2017/04/29 jQuery
基于BootStrap的文本编辑器组件Summernote
2017/10/27 Javascript
Vue中的slot使用插槽分发内容的方法
2018/03/01 Javascript
CentOS7中源码编译安装NodeJS的完整步骤
2018/10/13 NodeJs
微信小程序实现定位及到指定位置导航的示例代码
2019/08/20 Javascript
vue 解决数组赋值无法渲染在页面的问题
2019/10/28 Javascript
微信小程序request请求封装,验签代码实例
2019/12/04 Javascript
vue学习之Vue-Router用法实例分析
2020/01/06 Javascript
JavaScript设计模式之策略模式实现原理详解
2020/05/29 Javascript
[03:12]完美世界DOTA2联赛PWL DAY9集锦
2020/11/10 DOTA
python实现爬虫统计学校BBS男女比例之数据处理(三)
2015/12/31 Python
Python+微信接口实现运维报警
2016/08/27 Python
windows下pycharm安装、创建文件、配置默认模板
2018/07/31 Python
python的几种矩阵相乘的公式详解
2019/07/10 Python
python多线程共享变量的使用和效率方法
2019/07/16 Python
PyQt Qt Designer工具的布局管理详解
2019/08/07 Python
python配置文件写入过程详解
2019/10/19 Python
python爬虫库scrapy简单使用实例详解
2020/02/10 Python
利用三角函数在canvas上画虚线的方法
2018/01/11 HTML / CSS
Html5让容器充满屏幕高度或自适应剩余高度的布局实现
2020/05/14 HTML / CSS
办公室经理岗位职责
2014/01/01 职场文书
个人近期表现材料
2014/02/11 职场文书
平面设计求职信
2014/03/10 职场文书
学校募捐倡议书
2014/05/14 职场文书
2014年办公室个人工作总结
2014/11/12 职场文书
白鹤梁导游词
2015/02/06 职场文书
2015年实习生工作总结报告
2015/04/28 职场文书
护理工作心得体会
2016/01/22 职场文书
Python 数据可视化神器Pyecharts绘制图像练习
2022/02/28 Python