首页 存档 技术 查看内容

14 个必考的 JavaScript 面试题!

2018-3-30 13:00 |来自: 互联网 241 0

摘要: 进入企业第一步,肯定是免不了面试这一关的,小编今天为各位分享14个JavaScript面试考题(含答案),在各位学员在明年金三银四的招聘季一路过关斩将,赢得高薪工作!前端工程师有时候面试时会遇到一类面试官,他们问 ...

进入企业第一步,肯定是免不了面试这一关的,小编今天为各位分享14个JavaScript面试考题(含答案),在各位学员在明年金三银四的招聘季一路过关斩将,赢得高薪工作!

前端工程师有时候面试时会遇到一类面试官,他们问的问题对于语言本身非常较真儿,往往不是候选人可能期待的面向实际的问题(有些候选人强调能干活就行,至于知不知道其中缘由是无关痛痒的)。这类题目,虽然没有逻辑,但某种程度说,确实考察了候选人对于javascript这门语言的理解。

小编总结了14个JavaScript面试题,搬过来供大家学习、理解、背诵、批判。

问题一

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

arguments是一个Array-like对象,对应的就是传入函数的参数列表。你可以在任何函数中直接使用该变量。

typeof操作符只会返回string类型的结果。参照如下列表可知对应不同数据,typeof返回的值都是什么:

类型 结果
undefined 'undefined'
null 'object'
Boolean 'boolean'
Number 'number'
String 'string'
Symbol (new in ECMAScript 2015) 'symbol'
Host object (provided by the JS environment) Implementation-dependent
Function object (implements [[Call]] in ECMA-262 terms) 'function'
Any other object 'object'

由此我们推断出,typeof argumentsobject

问题二

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.propertydelete object['property']

delete操作符只能作用在对象的属性上,对变量和函数名无效。也就是说delete x是没有意义的。

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

问题四

var y = 1, x = y = typeof x; x;//"undefined"

我们试图分解上述代码成下面两步:

var y = 1; //step 1var 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"

声明:文章版权归原作者所有 部分文章转自互联网 如有侵权请联系 [邮箱地址] 删除


路过

雷人

握手

鲜花

鸡蛋

相关分类

返回顶部