Javascript的一些面试题让很多同学感到头疼,下面就根据兄弟连教育

)毕业学员面试遇到的面试题,给大家做一个简单的分享,希望对初入职场的你们有一些帮助:Javascript面试题解析。

第一题

/*

解析:

+ 优先级大于 ?

此题等价于: 'Value is true' ? 'Something' : 'Nothing'

所以结果是:'Something'

*/

var val = 'smtg';

console.log('Value is ' + (val === 'smtg') ?'Something' : 'Nothing');

第二题

/*

*解析:

*    typeof 返回一个表示类型的字符串

typeof的结果请看下面:

**type**         **result**

Undefined   "undefined"

Null        "object"

Boolean     "boolean"

Number      "number"

Symbol      "symbol"

Hostobject Implementation-dependent

Function    "function"

Object      "object"

instanceof运算符用来检测 constructor.prototype 是否存在于参数 object 的原型链上

所以输出["object",false]

*/

functiontwo(){

console.info([typeofnull, null instanceof Object]); //["object", false]

第三题

/*

[JavaScript中的稀疏数组与密集数组][1]

解析:

一般来说,JavaScript中的数组是稀疏的,也就是说,数组中的元素之间可以有空隙

其实在javascript中并没有常规的数组,所有的数组其实就是一个对象。

javascript的数组根本没有索引,因为索引是数字,而js中数组的索引是string,

arr[1]其实就是arr["1"],给arr["1000"] =1,arr.length也会自动变为1001.

这些表现的根本原因就是,JavaScript中的对象就是字符串到任意值的键值对.注意键只能是字符串.

看一下 Array.prototype.filter 的部分代码:

var t =Object(this);

var len =t.length >>> 0;

if (typeoffun !== 'function') {

thrownew TypeError();

}

var res =[];

varthisArg = arguments.length >= 2 ? arguments[1] : void 0;

for (var i= 0; i < len; i++) {

if (i int) { // 注意这里!!!

varval = t[i];

if(fun.call(thisArg, val, i, t)) {

res.push(val);

}

}

}

从上面可知filter对数组进行遍历时,会首先检查这个索引值是不是数组的一个属性.测试一下:

console.info(0 in ary); //true

console.info(1 in ary); //true

console.info(4 in ary); //false

console.info(10 in ary); // false

也就是说3~9的索引根本没有是初始化

所以答案:[];

*/

var ary = [0,1,2];

ary[10] = 10;

console.info(ary.filter(function(x) { return x ===undefined;}));

第四题

/*

解析:

y 被赋值到全局. x 是局部变量. 所以打印 x 的时候会报 ReferenceError

*/

(function(){

var x = y =1;

})();

console.log(y); // 1

console.log(x); // error

第五题

/*

解析:

当函数参数涉及到 any rest parameters,

anydefault parameters or any destructured parameters 的时候,

这个 arguments 就不在是一个 mapped arguments object 了.....,

所以答案是12,这个需要好好体会一下

*/

function sidEffecting(ary) {

ary[0] =ary[2];

}

function bar(a,b,c=3) {

c = 10

sidEffecting(arguments);

return a + b+ c;

}

bar(1,1,1);

Javascript面试题解析的更多相关文章

  1. 一个javascript面试题解析

    ; function fn(){ console.log(this.length); } var obj = { length: , method: function (fn) { fn(); // ...

  2. 互联网中级Javascript面试题

    互联网中级Javascript面试题 1.实现一个函数clone,可以对JavaScript中的5种主要的数据类型(包括Number.String.Object.Array.Boolean)进行值复制 ...

  3. 互联网公司前端初级Javascript面试题

    互联网公司前端初级Javascript面试题 1.JavaScript是一门什么样的语言,它有哪些特点?(简述javascript语言的特点)JavaScript是一种基于对象(Object)和事件驱 ...

  4. 【转】典型的JavaScript面试题

    问题1: 作用域(Scope) (function() { "use strict"; var a = b = 5; })(); console.log(b); 控制台(conso ...

  5. 2019年 Java 面试题解析

    2019年 Java 面试题解析 转载地址:https://www.cnblogs.com/Zz-maker/p/11193930.html 作者: Zz_maker 包含的模块: 本文分为十九个模块 ...

  6. 174道 JavaScript 面试题,助你查漏补缺

    最近在整理 JavaScript 的时候发现遇到了很多面试中常见的面试题,本部分主要是作者在 Github 等各大论坛收录的 JavaScript 相关知识和一些相关面试题时所做的笔记,分享这份总结给 ...

  7. [WebKit内核] JavaScript引擎深度解析--基础篇(一)字节码生成及语法树的构建详情分析

    [WebKit内核] JavaScript引擎深度解析--基础篇(一)字节码生成及语法树的构建详情分析 标签: webkit内核JavaScriptCore 2015-03-26 23:26 2285 ...

  8. [转]javascript eval函数解析json数据时为什加上圆括号eval("("+data+")")

    javascript eval函数解析json数据时为什么 加上圆括号?为什么要 eval这里要添加 “("("+data+")");//”呢?   原因在于: ...

  9. .NET面试题解析(11)-SQL语言基础及数据库基本原理

      系列文章目录地址: .NET面试题解析(00)-开篇来谈谈面试 & 系列文章索引 本文内容涉及到基本SQL语法,数据的基本存储原理,数据库一些概念.数据优化等.抱砖引玉,权当一个综合复习! ...

随机推荐

  1. 【Struts2】工作流程

    转发两篇文章 一个请求在Struts2框架中的处理分为以下几个步骤: 1.客户端发出一个指向servlet容器的请求(tomcat): 2.这个请求会经过图中的几个过滤器,最后会到达FilterDis ...

  2. 【Linux 应用编程】进程管理 - 进程间通信IPC之共享内存 mmap

    IPC(InterProcess Communication,进程间通信)是进程中的重要概念.Linux 进程之间常用的通信方式有: 文件:简单,低效,需要代码控制同步 管道:使用简单,默认阻塞 匿名 ...

  3. note.js 引用jQuery,

    1.安装jQuery npm install jquery 在自己的项目目录里面打开cmd进行安装 2.下面直接在js文件里面引用jQuery //调用jQuery来操作页面 const jsdom ...

  4. Fabric CA/数字证书管理

    MSP(Membership Service Provider)成员管理服务提供商 名词: 1.CSR(Cerificate Signing Request):证书签署请求文件 CSR里包含申请者的 ...

  5. Centos中使用Docker部署Apollo

    采用微服务开发框架开发项目时会涉及多个系统,如果要更改配置参数需要在多个系统间逐一更改,比较费时,而且容易遗漏,效率低下,次问题可以采用Apollo配置中心的方式解决,下面将介绍如何配置: 准备环境: ...

  6. Vue 2.0 入门系列(15)学习 Vue.js 需要掌握的 es6 (2)

    类与模块 类 es6 之前,通常使用构造函数来创建对象 // 构造函数 User function User(username, email) { this.username = username; ...

  7. 获取IP地址的几种方法

    根据ip获取地址的几种方法 1.调用新浪IP地址库 <script type="text/javascript" src="js/jquery.js"&g ...

  8. [LeetCode] 109. 有序链表转换二叉搜索树

    题目链接 : https://leetcode-cn.com/problems/convert-sorted-list-to-binary-search-tree/ 题目描述: 给定一个单链表,其中的 ...

  9. java 如何重写equal 和hashcode方法(最佳实践)

    先看完理解这篇:Java hashCode() 和 equals()的若干问题解答 实现高质量的equals方法的诀窍包括 使用==操作符检查“参数是否为这个对象的引用”: 使用instanceof操 ...

  10. 工作笔记之20170223:①关于Html5的placeholder属性,②以及input的outline:none的样式问题

    关于这边几个样式问题,重点有这么几个: (1)placeholder="请输入密码" (2) color:#BEB6B6; border:0px; border-bottom:1p ...