7 个去伪存真的 JavaScript 面试题

这次我要说的是如何淘汰那些滥竽充数的JavaScript程序员。

你会惊讶于居然有这么多人来面试工作,并且他们的简历描述得都貌似很牛逼的样子。但是如果你问他们相关问题的话,你就会发现他们对此一无所知。我不知道他们这些简历是真的还是只是一个噱头。所以和其他面试官一样,我也有我的一套方法首先确保面试的人是值得我去面试的——我可以在半小时内通过电话搞定。

javascript-2

因此,如果有些你认为应该有的问题却不在我的7个问题中,那可能是因为我将它放到了后面的面试环节里。

此外,我想对那些可能会认为技术面试并不能真正说明程序员是否真的优秀的人说……

你是对的。当我还是一个年轻的程序员时,如果面试技术问题,我也有同样的感觉。但现在,我成了面试官,我觉得这种方式,至少能证明那些通过技术面试的人比那些不能通过的人,是优秀程序员的可能性要大得多。

最后,我想说的是,我不会因为应聘者答错三两个问题或不按我预想地回答就将他们pass掉。但是,如果大多数问题对方都回答不出来的话,那我就会在心里给他亮起红灯!

下面这7个JavaScript面试问题是你应该在面试前先问的。否则,很有可能会浪费你的时间。

1.创建JavaScript对象的两种方法是什么?

这是一个非常简单的问题,如果你用过JavaScript的话。你至少得知道一种方法。但是,尽管如此,根据我的经验,也有很多自称是JavaScript程序员的人说不知道如何回答这个问题。

  • 使用“new”关键字来调用函数。
  • open/close花括号。

  1. var o = {};

你也可以继续提问,“什么情况下使用new关键字创建对象?”但是,由于我只是想淘汰一些人,所以这些问题我会等到真正面试的时候去问。

2.如何创建数组?

这和“如何创建对象”是相同级别的问题。然而,也有一些人回答得了第一个问题,却不能回答这个问题。

用下面的代码,简简单单就能创建一个数组:


  1. var myArray = new Array();

创建数组是一个很复杂的过程。但是我希望能从应聘者口中听到使用方括号的答案。


  1. var myArray = [];

当然,我们还可以继续问其他问题,比如如何高效地删除JavaScript数组中的重复元素等,但是由于我们只需要知道应聘人员是否值得进一步的观察,关于数组的问题我会到此结束。

3.什么是变量提升(Variable Hoisting)?

这个问题稍微难一点,我也并不要求对方一定得回答出来。但是,通过这个问题能够快速确定应聘者的技术水平:他们是否真的像他们声明得那样理解这门编程语言?

变量提升指的是,无论变量是在范围内的哪个地方声明的,JavaScript引擎都会将这个声明移到该范围的顶部。如果在函数中间声明一个变量,例如在某一行中赋值一个变量:


  1. function foo()
  2. {
  3. // 此处省略若干代码
  4. var a = "abc";
  5. }

实际上会这样运行代码:


  1. function foo()
  2. {
  3. var a;
  4. // 此处省略若干代码
  5. a = "abc";
  6. }

4.全局变量有什么风险,以及如何保护代码不受干扰?

全局变量的危险之处在于其他人可以创建相同名称的变量,然后覆盖你正在使用的变量。这在任何语言中都是一个令人头疼的问题。

预防的方法也有很多。其中最常用的方法是创建一个包含其他所有变量的全局变量:


  1. var applicationName = {};

然后,每当你需要创建一个全局变量的时候,将其附加到对象上即可。


  1. applicationName.myVariable = "abc";

还有一种方法是将所有的代码封装到一个自动执行的函数中,这样一来,所有声明的变量都声明在该函数的范围内。


  1. (function(){
  2. var a = "abc";
  3. })();

在现实中,这两种方法你可能都会用到。

5.如何迭代JavaScript对象的成员变量?


  1. for(var prop in obj){
  2. // bonus points for hasOwnProperty
  3. if(obj.hasOwnProperty(prop)){
  4. // do something here
  5. }
  6. }

6.什么是闭包(Closure)?

闭包允许一个函数定义在另一个外部函数的作用域内,即便作用域内的其他东西都消失了,它仍可以访问该外部函数内的变量。如果应聘者能够说明,在for/next循环中使用闭包却不声明变量来保存迭代变量当前值的一些风险,那就应该给对方加分。

7.请描述你经历过的JavaScript单元测试。

关于这个问题,其实我们只是想看看应聘人员是否真的做过JavaScript单元测试。这是一个开放式问题,没有特定的正确答案,不过对方至少得能讲述进程中的一些事情。

欢迎大家补充。

本文来自合作伙伴“Linux中国”,原文发布日期:2015-08-27

时间: 2024-11-01 10:46:47

7 个去伪存真的 JavaScript 面试题的相关文章

7个去伪存真的JavaScript面试题_javascript技巧

下面这7个JavaScript面试问题是你应该在面试前先问的.否则,很有可能会浪费你的时间.1.创建JavaScript对象的两种方法是什么?这是一个非常简单的问题,如果你用过JavaScript的话.你至少得知道一种方法.但是,尽管如此,根据我的经验,也有很多自称是JavaScript程序员的人说不知道如何回答这个问题. 使用"new"关键字来调用函数. open/close花括号. var o = {};你也可以继续提问,"使用new关键字,什么情况下创建对象?"

7个去伪存真的JavaScript面试题

上周,我发表了<C#程序员的7个面试问题>.这次我要说的是如何淘汰那些滥竽充数的JavaScript程序员. 你会惊讶于居然有这么多人来面试工作,并且他们的简历描述得都貌似很牛逼的样子.但是如果你问他们相关问题的话,你就会发现他们对此一无所知.我不 知道他们这些简历是真的还是只是一个噱头.所以和其他面试官一样,我也有我的一套方法首先确保面试的人是值得我去面试的--我可以在半小时内通过电话搞 定. 因此,如果有些你认为应该有的问题却不在我的7个问题中,那可能是因为我将它放到了后面的面试环节里.

人人网javascript面试题

JavaScript面试题要求:以下题目必须从一至四题中,选出三道题,使用原生代码实现,不可使 用任何框架,第五题为选作题. JavaScript面试题要求:以下题目必须从一至四题中,选出三道题,使用原生代码实现,不可使 用任何框架,第五题为选作题. 一.  在页面的固定区域内实现图片的展示    1.  每点击一次右箭头,图片区域向左滚动出一张图片,反之相同:    2.  当发现图片滚动到末尾时,响应的箭头变成不可点击状态:    3.  鼠标在图片区域内滑动滚轮,图片会随着鼠标滚轮的方向进

Javascript面试题

文章简介:Javascript面试题. 要求:1.只能在指定的位置填写自己的代码,本文件里的其他代码不能修改2.所有题目都不允许添加全局变量名3.本文件应该能在firebug的console里正常执行,并输出结果4.代码最优化,效率最高5.代码注释明确 练习1:实现一个遍历数组或对象里所有成员的迭代器. var each = function(obj, fn){         //+++++++++++答题区域+++++++++++                   //++++++++++

腾讯公司的javascript面试题

今天整理自己的文件夹时,发现了曾经面试腾讯实习生时的被问挂了的面试题,我将它们整理好了供大家借鉴.当时要求的是手写代码.汗啊,我那时弱爆了! 1,将给定数组转换为一个随机数组 Array.prototype.shuffle=function(){ var resultArr=[]; var len=this.length; while(len){ var _index=parseInt(Math.random()*len); resultArr.push(this[_index]);//每次取得

人人网javascript面试题 可以提前实现下_javascript技巧

JavaScript面试题要求:以下题目必须从一至四题中,选出三道题,使用原生代码实现,不可使 用任何框架,第五题为选作题. 一. 在页面的固定区域内实现图片的展示 1. 每点击一次右箭头,图片区域向左滚动出一张图片,反之相同: 2. 当发现图片滚动到末尾时,响应的箭头变成不可点击状态: 3. 鼠标在图片区域内滑动滚轮,图片会随着鼠标滚轮的方向进行响应的滚动: 二. 用 js.html.css实现一个弹出提示控件: 1. 分别实现类似于系统的 alert.confirm.prompt对话框: 2

极易被忽视的javascript面试题七问七答_javascript技巧

此题是我出的一套前端面试题中的最后一题,用来考核面试者的JavaScript的综合能力,很可惜到目前为止的将近两年中,几乎没有人能够完全答对,并非多难只是因为大多面试者过于轻视他. 题目如下: function Foo() { getName = function () { alert (1); }; return this; } Foo.getName = function () { alert (2);}; Foo.prototype.getName = function () { aler

JavaScript面试题(指针、帽子和女朋友)_javascript技巧

首先,事情开始于一道面试题 <script> function A(){ this.name=""; this.age=18; } var a1=new A(); a1.name="尼古拉斯·屌"; var a2=a1; a2.name="blue"; console.log(a1.name); //变成blue了 var str1="尼古拉斯·屌"; var str2=str1; str2="blue&

14 个折磨人的 JavaScript 面试题_javascript技巧

翻到了这篇解释Javascript quiz的文章quiz-legend,反正没事儿,就想搬过来供大家学习.理解.背诵.批判. 问题一 (function(){ return typeof arguments;//"object" })(); arguments是一个Array-like对象,对应的就是传入函数的参数列表.你可以在任何函数中直接使用该变量. typeof操作符只会返回string类型的结果.参照如下列表可知对应不同数据,typeof返回的值都是什么: 由此我们推断出,t