7个去伪存真的JavaScript面试题


Posted in Javascript onJanuary 07, 2016

下面这7个JavaScript面试问题是你应该在面试前先问的。否则,很有可能会浪费你的时间。
1.创建JavaScript对象的两种方法是什么?
这是一个非常简单的问题,如果你用过JavaScript的话。你至少得知道一种方法。但是,尽管如此,根据我的经验,也有很多自称是JavaScript程序员的人说不知道如何回答这个问题。

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

var o = {};
你也可以继续提问,“使用new关键字,什么情况下创建对象?”但是,由于我只是想淘汰一些人,所以这些问题我会等到真正面试的时候去问。
2.如何创建数组?
这和“如何创建对象”是相同级别的问题。然而,也有一些人回答得了第一个问题,却不能回答这个问题。
用下面的代码,简简单单就能创建一个数组:
var myArray = new Array();
创建数组是一个很复杂的过程。但是我希望能从应聘者口中听到使用方括号的答案。
var myArray = [];
当然,我们还可以继续问其他问题,比如如何高效地删除JavaScript数组中的重复元素等,但是由于我们只需要知道应聘人员是否值得进一步的观察,关于数组的问题我会到此结束。

再来针对如何高效地删除JavaScript数组中的重复元素说一说:js 如何实现数组去重整理出5种方法。

具体的方法介绍:

1).遍历数组法

最简单的去重方法, 实现思路:新建一新数组,遍历传入数组,值不在新数组就加入该新数组中;注意点:判断值是否在数组的方法“indexOf”是ECMAScript5 方法,IE8以下不支持,需多写一些兼容低版本浏览器代码,源码如下:

// 最简单数组去重法
function unique1(array){
 var n = []; //一个新的临时数组
 //遍历当前数组
 for(var i = 0; i < array.length; i++){
  //如果当前数组的第i已经保存进了临时数组,那么跳过,
  //否则把当前项push到临时数组里面
  if (n.indexOf(array[i]) == -1) n.push(array[i]);
 }
 return n;
}
// 判断浏览器是否支持indexOf ,indexOf 为ecmaScript5新方法 IE8以下(包括IE8, IE8只支持部分ecma5)不支持
if (!Array.prototype.indexOf){
 // 新增indexOf方法
 Array.prototype.indexOf = function(item){
  var result = -1, a_item = null;
  if (this.length == 0){
   return result;
  }
  for(var i = 0, len = this.length; i < len; i++){
   a_item = this[i];
   if (a_item === item){
    result = i;
    break;
   } 
  }
  return result;
 }
}

2).对象键值对法

该方法执行的速度比其他任何方法都快, 就是占用的内存大一些;实现思路:新建一js对象以及新数组,遍历传入数组时,判断值是否为js对象的键,不是的话给对象新增该键并放入新数组。注意点: 判断是否为js对象键时,会自动对传入的键执行“toString()”,不同的键可能会被误认为一样;例如: a[1]、a["1"] 。解决上述问题还是得调用“indexOf”。

// 速度最快, 占空间最多(空间换时间)
function unique2(array){
 var n = {}, r = [], len = array.length, val, type;
  for (var i = 0; i < array.length; i++) {
    val = array[i];
    type = typeof val;
    if (!n[val]) {
      n[val] = [type];
      r.push(val);
    } else if (n[val].indexOf(type) < 0) {
      n[val].push(type);
      r.push(val);
    }
  }
  return r;
}

3).数组下标判断法

还是得调用“indexOf”性能跟方法1差不多,实现思路:如果当前数组的第i项在当前数组中第一次出现的位置不是i,那么表示第i项是重复的,忽略掉。否则存入结果数组。

function unique3(array){
 var n = [array[0]]; //结果数组
 //从第二项开始遍历
 for(var i = 1; i < array.length; i++) {
  //如果当前数组的第i项在当前数组中第一次出现的位置不是i,
  //那么表示第i项是重复的,忽略掉。否则存入结果数组
  if (array.indexOf(array[i]) == i) n.push(array[i]);
 }
 return n;
}

4).排序后相邻去除法

虽然原生数组的”sort”方法排序结果不怎么靠谱,但在不注重顺序的去重里该缺点毫无影响。实现思路:给传入数组排序,排序后相同值相邻,然后遍历时新数组只加入不与前一值重复的值。

// 将相同的值相邻,然后遍历去除重复值
function unique4(array){
 array.sort(); 
 var re=[array[0]];
 for(var i = 1; i < array.length; i++){
  if( array[i] !== re[re.length-1])
  {
   re.push(array[i]);
  }
 }
 return re;
}

5).优化遍历数组法

源自外国博文,该方法的实现代码相当酷炫;实现思路:获取没重复的最右一值放入新数组。(检测到有重复值时终止当前循环同时进入顶层循环的下一轮判断)

// 思路:获取没重复的最右一值放入新数组
function unique5(array){
 var r = [];
 for(var i = 0, l = array.length; i < l; i++) {
  for(var j = i + 1; j < l; j++)
   if (array[i] === array[j]) j = ++i;
  r.push(array[i]);
 }
 return r;
}

3.什么是变量提升(Variable Hoisting)?
这个问题稍微难一点,我也并不要求对方一定得回答出来。但是,通过这个问题能够快速确定应聘者的技术水平:他们是否真的像他们声明得那样理解这门编程语言?
变量提升指的是,无论是哪里的变量在一个范围内声明的,那么JavaScript引擎会将这个声明移到范围的顶部。如果在函数中间声明一个变量,例如在某一行中赋值一个变量:

function foo()
{
 // 此处省略若干代码
 var a = "abc";
}
实际上会这样运行代码:
function foo()
{
 var a;
 // 此处省略若干代码
 a = "abc";
}

4.全局变量有什么风险,以及如何保护代码不受干扰?
全局变量的危险之处在于其他人可以创建相同名称的变量,然后覆盖你正在使用的变量。这在任何语言中都是一个令人头疼的问题。
预防的方法也有很多。其中最常用的方法是创建一个包含其他所有变量的全局变量:
var applicationName = {};
然后,每当你需要创建一个全局变量的时候,将其附加到对象上即可。
applicationName.myVariable = "abc";
还有一种方法是将所有的代码封装到一个自动执行的函数中,这样一来,所有声明的变量都声明在该函数的范围内。

(function(){
 var a = "abc";
})();

在现实中,这两种方法你可能都会用到。
5.如何通过JavaScript对象中的成员变量迭代?

for(var prop in obj){
 // bonus points for hasOwnProperty
 if(obj.hasOwnProperty(prop)){
  // do something here
 }
}

6.什么是闭包(Closure)?
闭包允许一个函数定义在另一个外部函数的作用域内,即便作用域内的其他东西都消失了,它仍可以访问该外部函数内的变量。如果应聘者能够说明,在for/next循环中使用闭包却不声明变量来保存迭代变量当前值的一些风险,那就应该给对方加分。
7.请描述你经历过的JavaScript单元测试。
关于这个问题,其实我们只是想看看应聘人员是否真的做过JavaScript单元测试。这是一个开放式问题,没有特定的正确答案,不过对方至少得能讲述进程中的一些事情。

以上就是为大家准备的JavaScript面试题,有没有做的很顺利,希望大家在面试之前查漏补缺,顺利过关。

Javascript 相关文章推荐
js中的如何定位固定层的位置
Jun 15 Javascript
Node.js中使用Log.io在浏览器中实时监控日志(等同tail -f命令)
Sep 17 Javascript
基于JavaScript实现简单的随机抽奖小程序
Jan 05 Javascript
Bootstrap入门书籍之(一)排版
Feb 17 Javascript
Jquery实现$.fn.extend和$.extend函数
Apr 14 Javascript
jQuery Easyui datagrid editor为combobox时指定数据源实例
Dec 19 Javascript
详解vue2.0的Element UI的表格table列时间戳格式化
Jun 13 Javascript
React中使用collections时key的重要性详解
Aug 07 Javascript
静态页面实现 include 引入公用代码的示例
Sep 25 Javascript
使用jQuery 操作table 完成单元格合并的实例
Dec 27 jQuery
vue实现城市列表选择功能
Jul 16 Javascript
Vue源码分析之Vue实例初始化详解
Aug 25 Javascript
jQuery表格插件datatables用法详解
Nov 23 #Javascript
详解JavaScript UTC时间转换方法
Jan 07 #Javascript
jQuery formValidator表单验证
Jan 07 #Javascript
JavaScript中的原始值和复杂值
Jan 07 #Javascript
理解JS事件循环
Jan 07 #Javascript
angularjs创建弹出框实现拖动效果
Aug 25 #Javascript
JavaScript中定义类的方式详解
Jan 07 #Javascript
You might like
DOTA2 1月28日更新:监管系统降临刀塔世界
2021/01/28 DOTA
PHP系统流量分析的程序
2006/10/09 PHP
UCenter 批量添加用户的php代码
2012/07/17 PHP
YII Framework教程之异常处理详解
2016/03/14 PHP
PHP实现的解汉诺塔问题算法示例
2018/08/06 PHP
基于Laravel 5.2 regex验证的正确写法
2019/09/29 PHP
PHP随机生成中文段落示例【测试网站内容时使用】
2020/04/26 PHP
给文字加上着重号的JS代码
2013/11/12 Javascript
jQuery 的全选(全非选)即取得被选中的值使用介绍
2013/11/12 Javascript
Jquery仿IGoogle实现可拖动窗口示例代码
2014/08/22 Javascript
实用框架(iframe)操作代码
2014/10/23 Javascript
js获取浏览器基本信息大全
2014/11/27 Javascript
JavaScript中日期函数的相关操作知识
2016/08/03 Javascript
jQuery ajax MD5实现用户注册即时验证功能
2016/10/11 Javascript
nodejs实现发出蜂鸣声音(系统报警声)的方法
2017/01/18 NodeJs
easyui关于validatebox实现多重规则验证的方法(必看)
2017/04/12 Javascript
微信小程序“摇一摇”的实例代码
2017/07/20 Javascript
利用纯JS实现像素逐渐显示的方法示例
2017/08/14 Javascript
vue设置导航栏、侧边栏为公共页面的例子
2019/11/01 Javascript
JS实现电脑虚拟键盘打字测试
2020/06/24 Javascript
vue实现下载文件流完整前后端代码
2020/11/17 Vue.js
[01:14]2019完美世界城市挑战赛(秋季赛)全国总决赛精彩花絮
2020/01/08 DOTA
Django1.7+python 2.78+pycharm配置mysql数据库
2016/10/09 Python
Python 'takes exactly 1 argument (2 given)' Python error
2016/12/13 Python
关于python的list相关知识(推荐)
2017/08/30 Python
用python编写第一个IDA插件的实例
2018/05/29 Python
Pandas之Fillna填充缺失数据的方法
2019/06/25 Python
opencv python 图像轮廓/检测轮廓/绘制轮廓的方法
2019/07/03 Python
python将字符串list写入excel和txt的实例
2019/07/20 Python
html5+css3之CSS中的布局与Header的实现
2014/11/21 HTML / CSS
捷克家电和家具购物网站:OKAY.cz
2020/07/23 全球购物
医学专业五年以上个人求职信
2013/12/03 职场文书
养成教育经验材料
2014/05/26 职场文书
HR在给员工开具离职证明时,需要注意哪些问题?
2019/07/03 职场文书
Ruby处理YAML和json数据
2022/04/18 Ruby
Python tensorflow卷积神经Inception V3网络结构
2022/05/06 Python