我错过的JS面试题,你别再错了。

这段时间在进行 web 前端的面试,在各大平台、社区寻找面试题,其中有一些基础的面试题,用来检查自己的基础的地方。

掘金上的 Cornad Li 将Github的一个很火的基础题翻译过来,自己试着做了一下,还是错了不少,有些是基础不牢,有些是粗心,用错题集整理一下,查漏补缺。

  1. global / window变量声明

下面代码会输出什么?

let greeting = "Halo";
greating = "Fuck JavaScript";
console.log(greating);

浏览器中当没有声明变量时(使用let const var等),会自动将变量声明为window/global的一个属性,并完成赋值,因此输出是:
"Fuck JavaScript"

  1. 当我们这样做时会发生什么?
function bark() {
  console.log("Woof!");
}
bark.animal = "dog";

A: Nothing, this is totally fine!
B: SyntaxError. You cannot add properties to a function this way.
C: undefined
D: ReferenceError
答案:A。因为在JavaScript中,函数也是一种对象,因此可以对其添加属性并赋值。

  1. 构造函数属性的添加

下面代码的输出是什么?

function Person(firstName, lastName) {
  this.firstName = firstName;
  this.lastName = lastName;
}

const member = new Person("Lydia", "Hallie");
Person.getFullName = () => this.firstName + this.lastName;

console.log(member.getFullName());

A: TypeError
B: SyntaxError
C: Lydia Hallie
D: undefined undefined
答案:A。构造函数添加属性,不能像一般对象那样直接添加,而是要在构造函数的原型上添加属性。像这样:

Person.prototype.getFullName = function() {
  return  this.firstName+this.lastName;
}
  1. this值 / new操作符流程

下面代码输出是什么?

function Person(firstName, lastName) {
  this.firstName = firstName;
  this.lastName = lastName;
}

const lydia = new Person("Lydia", "Hallie");
const sarah = Person("Sarah", "Smith");

console.log(sarah);

A. undefined
B. ReferenceError
C. {}
D. Person {firstName: "Sarah", lastName: "Smith"}
答案:A。由于lydia定义时 使用new关键词,因此lydia定义时的构造函数Person中的this是指lydia,而sarah定义时未使用关键词,因此构造函数中的this是定义的,也就是undefined,在非严格模式下,构造函数中的this就是window,因此window.firstNamewindow.lastName就是undefined
PS:在严格模式下,下面中会直接报错:Cannot set property 'firstName' of undefined

function Person(firstName, lastName) {
  "use strict";
  this.firstName = firstName;
  this.lastName = lastName;
  console.log(this);
}

const lydia = new Person("Lydia", "Hallie");
const sarah = Person("Sarah", "Smith");
/*  
[object Object] {
  firstName: "Lydia",
  lastName: "Hallie"
}  // lydia

"TypeError: Cannot set property 'firstName' of undefined  // sarah
*/
  1. 自加自减运算
let number = 0;
console.log(number++);
console.log(++number);
console.log(number);

A: 1 1 2
B: 1 2 2
C: 0 2 2
D: 0 1 2
答案: C。
后缀一元运算符++: 返回值 0,增加值 1
前缀一元运算符++: 增加值 2,返回值 2
MDN-Expressions_and_Operators

  1. 带标签的模板字符串

以下代码输出什么?

function getPersonInfo(one, two, three) {
  console.log(one);
  console.log(two);
  console.log(three);
}
const person = "Lydia";
const age = 21;
getPersonInfo`${person} is ${age} years old`;

A: Lydia 21 ["", "is", "years old"]
B: ["", "is", "years old"] Lydia 21
C: Lydia ["", "is", "years old"] 21
答案:B。带标签的模板字符串第一个参数包含一个字符串值的数组,其余参数与表达式相关。因此two, three分别是${person}, ${age}

  1. 基础类型和引用类型区别

以下代码输出什么?

function checkAge(data) {
  if (data === { age: 18 }) {
    console.log("You are an adult!");
  } else if (data == { age: 18 }) {
    console.log("You are still an adult.");
  } else {
    console.log(`Hmm.. You don't have an age I guess`);
  }
}
checkAge({ age: 18 });

A: You are an adult!
B: You are still an adult.
C: Hmm.. You don't have an age I guess
答案: C。涉及到基础类型和引用类型的比较。原始类型通过值去比较,只要值相等,两个就相等。而引用类型(对象)通过他们的引用的内存地址是否一样去比较相似性。JavaScript检查对象是否具有对内存中相同位置的引用。这就是为什么{ age: 18 } === { age: 18 }和 { age: 18 } == { age: 18 } 返回 false的原因。

  1. 拓展运算符
    以下代码输出什么?
function getAge(...args) {
  console.log(typeof args);
}
getAge(21);

A: "number"
B: "array"
C: "object"
D: "NaN"
答案:C。扩展运算符(... args)返回一个带参数的数组。 数组是一个对象,因此typeof args返回object。

  1. 严格模式下的引用错误。
function getAge() {
  "use strict";
  age = 21;
  console.log(age);
}
getAge();

A: 21
B: undefined
C: ReferenceError
D: TypeError
答案:C。使用严格模式"use strict";可以确保不会意外地生成全局变量,我们从未声明变量age,因为我们使用``use strict',它会引发一个ReferenceError。 如果我们不使用“use strict”,它就会起作用,因为属性age`会被添加到全局对象中。

  1. sessionStorage, localStorage

cool_secret可以访问多长时间?

sessionStorage.setItem("cool_secret", 123);

A:永远,数据不会丢失。
B:用户关闭选项卡时。
C:当用户关闭整个浏览器时,不仅是选项卡。
D:用户关闭计算机时。
答案: B。
关闭选项卡后,将删除存储在sessionStorage中的数据。如果使用localStorage,数据将永远存在,除非例如调localStorage.clear()
MDN-sessionStorage
MDN-localStorage

  1. continue关键字

下面代码的输出是什么?

for (let i = 1; i < 5; i++) {
  if (i === 3) continue;
  console.log(i);
}

A: 1 2
B: 1 2 3
C: 1 2 4
D: 1 3 4
答案: C。
如果某个条件返回true,则continue语句跳过迭代。

  1. 基本类型的装箱转换

下面代码的输出是什么?

String.prototype.giveLydiaPizza = () => {
  return "Just give Lydia pizza already!";
};
const name = "Lydia";
name.giveLydiaPizza();

A: "Just give Lydia pizza already!"
B: TypeError: not a function
C: SyntaxError
D: undefined
答案: A。
String是一个内置的构造函数,我们可以为它添加属性。 我刚给它的原型添加了一个方法。 原始类型的字符串自动转换为字符串对象,由字符串原型函数生成。 因此,所有字符串(字符串对象)都可以访问该方法!
译者ConardLi 注:
当使用基本类型的字符串调用giveLydiaPizza时,实际上发生了下面的过程:

  • 创建一个String的包装类型实例
  • 在实例上调用substring方法
  • 销毁实例

学习者注:也就是基础类型转化为引用类型的 "装箱转换",这使得基础类型例如string, number, boolean 的变量可以调用其对应复杂类型对象上的方法。

  1. 对象键值自动转化为字符串。

下面代码的输出是什么?

const a = {};
const b = { key: "b" };
const c = { key: "c" };
a[b] = 123;
a[c] = 456;
console.log(a[b]);

A: 123
B: 456
C: undefined
D: ReferenceError
答案: B
对象键自动转换为字符串。我们试图将一个对象设置为对象a的键,其值为123。
但是,当对象自动转换为字符串化时,它变成了[Object object]。 所以我们在这里说的是a["Object object"] = 123。 然后,我们可以尝试再次做同样的事情。 c对象同样会发生隐式类型转换。那么,a["Object object"] = 456。
然后,我们打印a[b],它实际上是a["Object object"]。 我们将其设置为456,因此返回456。
此时打印出a, b, c分别是:

[object Object] {
  [object Object]: 456
}  // a
[object Object] {
  key: "b"
}  // b
[object Object] {
  key: "c"
}  // c
  1. 单击按钮时event.target是什么?
<div onclick="console.log('first div')">
  <div onclick="console.log('second div')">
    <button onclick="console.log('button')">
      Click!
    </button>
  </div>
</div>

A: div外部
B: div内部
C: button
D: 所有嵌套元素的数组.
答案: C。
导致事件的最深嵌套元素是事件的目标。 可以通过在需要停止冒泡的地方用 event.stopPropagation 停止冒泡。

document.querySelector('button').addEventListener('click', event=> {
  event.stopPropagation();
  console.log(event.target);
});
/* 
button   
<button onclick="console.log('button')">Click!
</button>
*/
  1. 块级作用域。

下面代码的输出是什么?

(() => {
  let x, y;
  try {
    throw new Error();
  } catch (x) {
    (x = 1), (y = 2);
    console.log(x);
  }
  console.log(x);
  console.log(y);
})();

A: 1 undefined 2
B: undefined undefined undefined
C: 1 1 2
D: 1 undefined undefined
答案: A。
catch作用域中的x与外面的x不同,不是同一个x
catch中的赋值,对catch外的x没有作用,对y有作用,因为y的赋值是catch在作用域链上对外部y的赋值。
x还是undefinedy被赋值为2。

  1. JavaScript中的所有内容都是...

A:原始或对象
B:函数或对象
C:技巧问题!只有对象
D:数字或对象
答案: A
JavaScript只有原始类型和对象。
原始类型是boolean,null,undefined,bigint,number,string和symbol

  1. JavaScript单变量的布尔值转换

下面代码的输出是什么?

!!null;
!!"";
!!1;

A: false true false
B: false false true
C: false true true
D: true true false
答案: B
null是假值。 !null返回true!true返回false
""是假值。 !""返回true!true返回false
1是真值。 !1返回false!false返回true
学习者注:JavaScript的单变量布尔值的转化中,以下几种为false,其余为truenull, undefined, '', NaN, 0,false

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352