14 个折磨人的 JavaScript 面试题


Posted in Javascript onAugust 08, 2016

翻到了这篇解释Javascript quiz的文章quiz-legend,反正没事儿,就想搬过来供大家学习、理解、背诵、批判。

问题一

(function(){
 return typeof arguments;//"object"
})();

arguments是一个Array-like对象,对应的就是传入函数的参数列表。你可以在任何函数中直接使用该变量。
typeof操作符只会返回string类型的结果。参照如下列表可知对应不同数据,typeof返回的值都是什么:

14 个折磨人的 JavaScript 面试题

由此我们推断出,typeof arguments是object 

问题二

var f = function g(){ return 23; };
typeof g();//报错

这是一个名字是g的function expression,然后又被赋值给了变量f。
 这里的函数名g和被其赋值的变量f有如下差异:
 函数名g不能变动,而变量f可以被重新赋值
 函数名g只能在函数体内部被使用,试图在函数外部使用g会报错的 

问题三

(function(x){
 delete x;
 return x;//1
})(1);

delete操作符可以从对象中删除属性,正确用法如下:
delete object.property
delete object['property']
delete操作符只能作用在对象的属性上,对变量和函数名无效。也就是说delete x是没有意义的。 

你最好也知道,delete是不会直接释放内存的,她只是间接的中断对象引用 

问题四
var y = 1, x = y = typeof x; x;//"undefined"
我们试图分解上述代码成下面两步:
var y = 1; //step 1
var x = y = typeof x; //step 2
第一步应该没有异议,我们直接看第二步
 1.赋值表达式从右向左执行
 2.y被重新赋值为typeof x的结果,也就是undefined
 3.x被赋值为右边表达式(y = typeof x)的结果,也就是undefined 

问题五

(function f(f){
 return typeof f();//"number"
})(function(){ return 1; });

直接上注释解释:

(function f(f){
 //这里的f是传入的参数function(){ return 1; }
 //执行的结果自然是1
 return typeof f(); //所以根据问题一的表格我们知道,typeof 1结果是"number"
})(function(){ return 1; });

问题六

var foo = {
 bar: function() { return this.baz; },
 baz: 1
};

(function(){
 return typeof arguments[0]();//"undefined"
})(foo.bar);

这里你可能会误以为最终结果是number。向函数中传递参数可以看作是一种赋值,所以arguments[0]得到是是真正的bar函数的值,而不是foo.bar这个引用,那么自然this也就不会指向foo,而是window了。 

问题七

var foo = {
 bar: function(){ return this.baz; },
 baz: 1
}
typeof (f = foo.bar)();//"undefined"

这和上一题是一样的问题,(f = foo.bar)返回的就是bar的值,而不是其引用,那么this也就指的不是foo了。 

问题八 

var f = (function f(){ return '1'; }, function g(){ return 2; })();
typeof f;//"number"

逗号操作符 对它的每个操作对象求值(从左至右),然后返回最后一个操作对象的值 

所以(function f(){ return '1'; }, function g(){ return 2; })的返回值就是函数g,然后执行她,那么结果是2;最后再typeof 2,根据问题一的表格,结果自然是number 

问题九

var x = 1;
if (function f(){}) {
 x += typeof f;
}
x;//"1undefined"

这个问题的关键点,我们在问题二中谈到过,function expression中的函数名f是不能在函数体外部访问的

问题十

var x = [typeof x, typeof y][1];
typeof typeof x;//"string" 1.因为没有声明过变量y,所以typeof y返回"undefined"

 2.将typeof y的结果赋值给x,也就是说x现在是"undefined"
 3.然后typeof x当然是"string"
 4.最后typeof "string"的结果自然还是"string" 

问题十一 

(function(foo){
 return typeof foo.bar;//"undefined"
})({ foo: { bar: 1 } });

这是个纯粹的视觉诡计,上注释

(function(foo){

 //这里的foo,是{ foo: { bar: 1 } },并没有bar属性哦。
 //bar属性是在foo.foo下面
 //所以这里结果是"undefined"
 return typeof foo.bar;
})({ foo: { bar: 1 } });

问题十二

(function f(){
 function f(){ return 1; }
 return f();//2
 function f(){ return 2; }
})();

通过function declaration声明的函数甚至可以在声明之前使用,这种特性我们称之为hoisting。于是上述代码其实是这样被运行环境解释的:

(function f(){
 function f(){ return 1; }
 function f(){ return 2; }
 return f();
})();

问题十三

function f(){ return f; }
new f() instanceof f;//false

当代码new f()执行时,下面事情将会发生:
 1.一个新对象被创建。它继承自f.prototype
 2.构造函数f被执行。执行的时候,相应的传参会被传入,同时上下文(this)会被指定为这个新实例。new f等同于new f(),只能用在不传递任何参数的情况。
 3.如果构造函数返回了一个“对象”,那么这个对象会取代整个new出来的结果。如果构造函数没有返回对象,那么new出来的结果为步骤1创建的对象, 

ps:一般情况下构造函数不返回任何值,不过用户如果想覆盖这个返回值,可以自己选择返回一个普通对象来覆盖。当然,返回数组也会覆盖,因为数组也是对象。 

于是,我们这里的new f()返回的仍然是函数f本身,而并非他的实例 

问题十四
 with (function(x, undefined){}) length;//2
with语句将某个对象添加的作用域链的顶部,如果在statement中有某??未使用命名空间的变量,跟作用域链中的某??属性同名,?t???变量将指向???属性值。如果?]有同名的属性,则将??出ReferenceError异常。 

OK,现在我们来看,由于function(x, undefined){}是一个匿名函数表达式,是函数,就会有length属性,指的就是函数的参数个数。所以最终结果就是2了 

写在最后

有人觉得这些题坑爹,也有人觉得开阔了眼界,见仁见智吧。但有一件事是真的,无论你是否坚定的实践派,缺了理论基础,也铁定走不远 - 你永远不会见到哪个熟练的技术工人突然成了火箭专家。 

看文档、读标准、结合实践,才是同志们的决胜之道。

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

Javascript 相关文章推荐
AJAX异步从优酷专辑中采集所有视频及信息(JavaScript代码)
Nov 20 Javascript
jQuery简单几行代码实现tab切换
Mar 10 Javascript
过期软件破解办法实例详解
Jan 04 Javascript
从零学习node.js之mysql数据库的操作(五)
Feb 24 Javascript
angular+ionic返回上一页并刷新页面
Aug 08 Javascript
基于JavaScript实现表格滚动分页
Nov 22 Javascript
微信小程序实现打开内置地图功能【附源码下载】
Dec 07 Javascript
jQuery实现模糊查询的方法分析
May 10 jQuery
AngularJS模态框模板ngDialog的使用详解
May 11 Javascript
RxJS的入门指引和初步应用
Jun 15 Javascript
小程序卡片切换效果组件wxCardSwiper的实现
Feb 13 Javascript
解决ant-design-vue中menu菜单无法默认展开的问题
Oct 31 Javascript
js中 计算两个日期间的工作日的简单实例
Aug 08 #Javascript
WebSocket+node.js创建即时通信的Web聊天服务器
Aug 08 #Javascript
学习Javascript闭包(Closure)知识
Aug 07 #Javascript
JavaScript实现in-place思想的快速排序方法
Aug 07 #Javascript
使用jQuery调用XML实现无刷新即时聊天
Aug 07 #Javascript
JS中使用FormData上传文件、图片的方法
Aug 07 #Javascript
深入理解Angular2 模板语法
Aug 07 #Javascript
You might like
PHP的pcntl多进程用法实例
2015/03/19 PHP
PHP实现的迪科斯彻(Dijkstra)最短路径算法实例
2017/09/16 PHP
javascript onkeydown,onkeyup,onkeypress,onclick,ondblclick
2009/02/04 Javascript
javascript 写类方式之八
2009/07/05 Javascript
JavaScript DOM学习第六章 表单实例
2010/02/19 Javascript
NodeJS 模块开发及发布详解分享
2012/03/07 NodeJs
JS中不为人知的五种声明Number的方式简要概述
2013/02/22 Javascript
编程语言JavaScript简介
2014/10/16 Javascript
实例详解Nodejs 保存 payload 发送过来的文件
2016/01/14 NodeJs
JS实现将Asp.Net的DateTime Json类型转换为标准时间的方法
2016/08/02 Javascript
Javascript中数组去重与拍平的方法示例
2017/02/03 Javascript
React-Native之定时器Timer的实现代码
2017/10/04 Javascript
vue.js实现三级菜单效果
2019/10/19 Javascript
浅谈JavaScript 声明提升
2020/09/14 Javascript
[06:40]2014DOTA2西雅图国际邀请赛 DK战队巡礼
2014/07/07 DOTA
web.py在模板中输出美元符号的方法
2014/08/26 Python
Python中暂存上传图片的方法
2015/02/18 Python
python读取与写入csv格式文件的示例代码
2017/12/16 Python
在Django中输出matplotlib生成的图片方法
2018/05/24 Python
django 控制页面跳转的例子
2019/08/06 Python
python tkinter图形界面代码统计工具(更新)
2019/09/18 Python
用Python绘制漫步图实例讲解
2020/02/26 Python
MoviePy简介及Python视频剪辑自动化
2020/12/18 Python
如何利用CSS3制作3D效果文字具体实现样式
2013/05/02 HTML / CSS
实例教程 纯CSS3打造非常炫的加载动画效果
2014/11/05 HTML / CSS
Perfume’s Club德国官网:在线购买香水
2019/04/08 全球购物
新奥尔良珠宝:Mignon Faget
2020/11/23 全球购物
两则小学生的自我评价分享
2013/11/14 职场文书
高中班主任评语大全
2014/04/25 职场文书
承诺书格式范文
2014/06/03 职场文书
高校自主招生校长推荐信
2015/03/23 职场文书
消防隐患整改通知书
2015/04/22 职场文书
2015年村计划生育工作总结
2015/04/28 职场文书
2015年助理政工师工作总结
2015/05/26 职场文书
pandas:get_dummies()与pd.factorize()的用法及区别说明
2021/05/21 Python
python关于集合的知识案例详解
2021/05/30 Python