43道JavaScript面试题

2023-11-11

1. 下面代码的输出是什么?
  function sayHi() {
        console.log(name)
        console.log(age)
        var name = 'Lydia'
        let age = 21
      }
      sayHi()

复制

  • A: Lydiaundefined
  • B: LydiaReferenceError
  • C: ReferenceError21
  • D: undefinedReferenceError
答案: D

在函数中,我们首先使用var关键字声明了name变量。 这意味着变量在创建阶段会被提升(JavaScript会在创建变量创建阶段为其分配内存空间),默认值为undefined,直到我们实际执行到使用该变量的行。 我们还没有为name变量赋值,所以它仍然保持undefined的值。

使用let关键字(和const)声明的变量也会存在变量提升,但与var不同,初始化没有被提升。 在我们声明(初始化)它们之前,它们是不可访问的。 这被称为“暂时死区”。 当我们在声明变量之前尝试访问变量时,JavaScript会抛出一个ReferenceError

译者注:

关于let的是否存在变量提升,我们何以用下面的例子来验证:

let name = 'ConardLi'{  console.log(name) // Uncaught ReferenceError: name is not defined  let name = 'code秘密花园'}

复制

let变量如果不存在变量提升,console.log(name)就会输出ConardLi,结果却抛出了ReferenceError,那么这很好的说明了,let也存在变量提升,但是它存在一个“暂时死区”,在变量未初始化或赋值前不允许访问。

变量的赋值可以分为三个阶段:

  • 创建变量,在内存中开辟空间
  • 初始化变量,将变量初始化为undefined
  • 真正赋值

关于letvarfunction

  • let 的「创建」过程被提升了,但是初始化没有提升。
  • var 的「创建」和「初始化」都被提升了。
  • function 的「创建」「初始化」和「赋值」都被提升了。

2. 下面代码的输出是什么?
for (var i = 0; i < 3; i++) {  setTimeout(() => console.log(i), 1);}for (let i = 0; i < 3; i++) {  setTimeout(() => console.log(i), 1);}

复制

  • A: 0 1 2 and 0 1 2
  • B: 0 1 2 and 3 3 3
  • C: 3 3 3 and 0 1 2
答案: C

由于JavaScript中的事件执行机制,setTimeout函数真正被执行时,循环已经走完。 由于第一个循环中的变量i是使用var关键字声明的,因此该值是全局的。 在循环期间,我们每次使用一元运算符++都会将i的值增加1。 因此在第一个例子中,当调用setTimeout函数时,i已经被赋值为3

在第二个循环中,使用let关键字声明变量i:使用let(和const)关键字声明的变量是具有块作用域的(块是{}之间的任何东西)。 在每次迭代期间,i将被创建为一个新值,并且每个值都会存在于循环内的块级作用域。


3. 下面代码的输出是什么?
const shape = {  radius: 10,  diameter() {    return this.radius * 2;  },  perimeter: () => 2 * Math.PI * this.radius};shape.diameter();shape.perimeter();

复制

  • A: 20 and 62.83185307179586
  • B: 20 and NaN
  • C: 20 and 63
  • D: NaN and 63
答案: B

请注意,diameter是普通函数,而perimeter是箭头函数。

对于箭头函数,this关键字指向是它所在上下文(定义时的位置)的环境,与普通函数不同! 这意味着当我们调用perimeter时,它不是指向shape对象,而是指其定义时的环境(window)。没有值radius属性,返回undefined


4. 下面代码的输出是什么?
+true;!"Lydia";

复制

  • A: 1 and false
  • B: false and NaN
  • C: false and false
答案: A

一元加号会尝试将boolean类型转换为数字类型。 true被转换为1false被转换为0

字符串'Lydia'是一个真值。 我们实际上要问的是“这个真值是假的吗?”。 这会返回false


5. 哪个选项是不正确的?
const bird = {  size: "small"};const mouse = {  name: "Mickey",  small: true};

复制

  • A: mouse.bird.size
  • B: mouse[bird.size]
  • C: mouse[bird["size"]]
  • D: All of them are valid
答案: A

JavaScript中,所有对象键都是字符串(除了Symbol)。尽管有时我们可能不会给定字符串类型,但它们总是被转换为字符串。

JavaScript解释语句。当我们使用方括号表示法时,它会看到第一个左括号[,然后继续,直到找到右括号]。只有在那个时候,它才会对这个语句求值。

mouse [bird.size]:首先它会对bird.size求值,得到smallmouse [“small”]返回true

但是,使用点表示法,这不会发生。 mouse没有名为bird的键,这意味着mouse.birdundefined。 然后,我们使用点符号来询问sizemouse.bird.size。 由于mouse.birdundefined,我们实际上是在询问undefined.size。 这是无效的,并将抛出Cannot read property "size" of undefined



6. 下面代码的输出是什么?
let c = { greeting: "Hey!" };
let d;
d = c;
c.greeting = "Hello";
console.log(d.greeting);

复制

  • A: Hello
  • B: undefined
  • C: ReferenceError
  • D: TypeError
答案: A

JavaScript中,当设置它们彼此相等时,所有对象都通过引用进行交互。

首先,变量c为对象保存一个值。 之后,我们将d指定为c与对象相同的引用。

image.gif

更改一个对象时,可以更改所有对象。


7. 下面代码的输出是什么?
 let a = 3
      let b = new Number(3)
      let c = 3
      console.log(a == b)
      console.log(a === b)
      console.log(b === c)

复制

  • A: true false true
  • B: false false true
  • C: true false false
  • D: false true true
答案: C

new Number()是一个内置的函数构造函数。 虽然它看起来像一个数字,但它并不是一个真正的数字:它有一堆额外的功能,是一个对象。

当我们使用==运算符时,它只检查它是否具有相同的值。 他们都有3的值,所以它返回true

译者注:==会引发隐式类型转换,右侧的对象类型会自动拆箱为Number类型。

然而,当我们使用===操作符时,类型和值都需要相等,new Number()不是一个数字,是一个对象类型。两者都返回 false


8. 下面代码的输出是什么?
 class Chameleon {
        static colorChange(newColor) {
          this.newColor = newColor
        }
        constructor({ newColor = 'green' } = {}) {
          this.newColor = newColor
        }
      }
      const freddie = new Chameleon({ newColor: 'purple' })
      freddie.colorChange('orange')

复制

  • A: orange
  • B: purple
  • C: green
  • D: TypeError
答案: D

colorChange方法是静态的。 静态方法仅在创建它们的构造函数中存在,并且不能传递给任何子级。 由于freddie是一个子级对象,函数不会传递,所以在freddie实例上不存在freddie方法:抛出TypeError


9. 下面代码的输出是什么?
   let greeting
      greetign = {} // Typo!console.log(greetign);

复制

  • A: {}
  • B: ReferenceError: greetign is not defined
  • C: undefined
答案: A

控制台会输出空对象,因为我们刚刚在全局对象上创建了一个空对象! 当我们错误地将greeting输入为greetign时,JS解释器实际上在浏览器中将其视为global.greetign = {}(或window.greetign = {})。

为了避免这种情况,我们可以使用“use strict”。 这可以确保在将变量赋值之前必须声明变量。


10. 当我们这样做时会发生什么?
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中是可能的,因为函数也是对象!(原始类型之外的所有东西都是对象)

函数是一种特殊类型的对象。您自己编写的代码并不是实际的函数。 该函数是具有属性的对象,此属性是可调用的。


11. 下面代码的输出是什么?
  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}`
      }

复制

这样会使member.getFullName()是可用的,为什么样做是对的? 假设我们将此方法添加到构造函数本身。 也许不是每个Person实例都需要这种方法。这会浪费大量内存空间,因为它们仍然具有该属性,这占用了每个实例的内存空间。 相反,如果我们只将它添加到原型中,我们只需将它放在内存中的一个位置,但它们都可以访问它!


12. 下面代码的输出是什么?
 function Person(firstName, lastName) {
        this.firstName = firstName
        this.lastName = lastName
      }
      const lydia = new Person('Lydia', 'Hallie')
      const sarah = Person('Sarah', 'Smith')
      console.log(lydia)
      console.log(sarah)

复制

  • A: Person {firstName: "Lydia", lastName: "Hallie"} and undefined
  • B: Person {firstName: "Lydia", lastName: "Hallie"} and Person {firstName: "Sarah", lastName: "Smith"}
  • C: Person {firstName: "Lydia", lastName: "Hallie"} and {}
  • D:Person {firstName: "Lydia", lastName: "Hallie"} and ReferenceError
答案: A

对于sarah,我们没有使用new关键字。 使用new时,它指的是我们创建的新空对象。 但是,如果你不添加new它指的是全局对象!

我们指定了this.firstName等于'Sarahthis.lastName等于Smith。 我们实际做的是定义global.firstName ='Sarah'global.lastName ='Smithsarah本身的返回值是undefined


12. 事件传播的三个阶段是什么??
  • A: 目标 > 捕获 > 冒泡
  • B: 冒泡 > 目标 > 捕获
  • C: 目标 > 冒泡 > 捕获
  • D: 捕获 > 目标 > 冒泡
答案: D

在捕获阶段,事件通过父元素向下传递到目标元素。 然后它到达目标元素,冒泡开始。

image.gif


13. 所有对象都有原型.
  • A: 对
  • B: 错误
答案: B

基础对象外,所有对象都有原型。 基础对象可以访问某些方法和属性,例如.toString。 这就是您可以使用内置JavaScript方法的原因! 所有这些方法都可以在原型上找到。 虽然JavaScript无法直接在您的对象上找到它,但它会沿着原型链向下寻找并在那里找到它,这使您可以访问它。

译者注:基础对象指原型链终点的对象。基础对象的原型是null


14. 下面代码的输出是什么?
function sum(a, b) {  return a + b;}sum(1, "2");

复制

  • A: NaN
  • B: TypeError
  • C: "12"
  • D: 3
答案: C

JavaScript是一种动态类型语言:我们没有指定某些变量的类型。 在您不知情的情况下,值可以自动转换为另一种类型,称为隐式类型转换。 强制从一种类型转换为另一种类型。

在此示例中,JavaScript将数字1转换为字符串,以使函数有意义并返回值。 在让数字类型(1)和字符串类型('2')相加时,该数字被视为字符串。 我们可以连接像“Hello”+“World”这样的字符串,所以这里发生的是“1”+“2”返回“12”


15. 下面代码的输出是什么?
  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

后缀一元运算符++

  1. 返回值(返回0
  2. 增加值(数字现在是1

前缀一元运算符++

  1. 增加值(数字现在是2
  2. 返回值(返回2

所以返回0 2 2


16. 下面代码的输出是什么?
 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

如果使用标记的模板字符串,则第一个参数的值始终是字符串值的数组。 其余参数获取传递到模板字符串中的表达式的值!


17. 下面代码的输出是什么?
  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的原因。


18. 下面代码的输出是什么?
function getAge(...args) {  console.log(typeof args);}getAge(21);

复制

  • A: "number"
  • B: "array"
  • C: "object"
  • D: "NaN"
答案: C

扩展运算符(... args)返回一个带参数的数组。 数组是一个对象,因此typeof args返回object


20. 下面代码的输出是什么?
    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`会被添加到全局对象中。


21. 下面代码的输出是什么?
const sum = eval("10*10+5");

复制

  • A: 105
  • B: "105"
  • C: TypeError
  • D: "10*10+5"
答案: A

eval会为字符串传递的代码求值。 如果它是一个表达式,就像在这种情况下一样,它会计算表达式。 表达式为10 * 10 + 5计算得到105


22. cool_secret可以访问多长时间?
sessionStorage.setItem("cool_secret", 123);

复制

  • A:永远,数据不会丢失。
  • B:用户关闭选项卡时。
  • C:当用户关闭整个浏览器时,不仅是选项卡。
  • D:用户关闭计算机时。
答案: B

关闭选项卡后,将删除存储在sessionStorage中的数据。

如果使用localStorage,数据将永远存在,除非例如调用localStorage.clear()


23. 下面代码的输出是什么?
var num = 8;var num = 10;console.log(num);

复制

  • A: 8
  • B: 10
  • C: SyntaxError
  • D: ReferenceError
答案: B

使用var关键字,您可以用相同的名称声明多个变量。然后变量将保存最新的值。

您不能使用letconst来实现这一点,因为它们是块作用域的。


24. 下面代码的输出是什么?
  const obj = { 1: 'a', 2: 'b', 3: 'c' }
      const set = new Set([1, 2, 3, 4, 5])
      obj.hasOwnProperty('1')
      obj.hasOwnProperty(1)
      set.has('1')
      set.has(1)

复制

  • A: false true false true
  • B: false true true true
  • C: true true false true
  • D: true true true true
答案: C

所有对象键(不包括Symbols)都会被存储为字符串,即使你没有给定字符串类型的键。 这就是为什么obj.hasOwnProperty('1')也返回true

上面的说法不适用于Set。 在我们的Set中没有“1”set.has('1')返回false。 它有数字类型1set.has(1)返回true


25. 下面代码的输出是什么?
  const obj = { a: 'one', b: 'two', a: 'three' }
      console.log(obj)

复制

  • A: { a: "one", b: "two" }
  • B: { b: "two", a: "three" }
  • C: { a: "three", b: "two" }
  • D: SyntaxError
答案: C

如果对象有两个具有相同名称的键,则将替前面的键。它仍将处于第一个位置,但具有最后指定的值。


26. JavaScript全局执行上下文为你创建了两个东西:全局对象和this关键字.
  • A: 对
  • B: 错误
  • C: 视情况而定
答案: A

基本执行上下文是全局执行上下文:它是代码中随处可访问的内容。


27. 下面代码的输出是什么?
  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语句跳过迭代。


28. 下面代码的输出是什么?
  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是一个内置的构造函数,我们可以为它添加属性。 我刚给它的原型添加了一个方法。 原始类型的字符串自动转换为字符串对象,由字符串原型函数生成。 因此,所有字符串(字符串对象)都可以访问该方法!

译者注:

当使用基本类型的字符串调用giveLydiaPizza时,实际上发生了下面的过程:

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

29. 下面代码的输出是什么?
  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


30. 下面代码的输出是什么?
  const foo = () => console.log('First')
      const bar = () => setTimeout(() => console.log('Second'))
      const baz = () => console.log('Third')
      bar()
      foo()
      baz()

复制

  • A: First Second Third
  • B: First Third Second
  • C: Second First Third
  • D: Second Third First
答案: B

我们有一个setTimeout函数并首先调用它。 然而却最后打印了它。

这是因为在浏览器中,我们不只有运行时引擎,我们还有一个叫做WebAPI的东西。WebAPI为我们提供了setTimeout函数,例如DOM

callback推送到WebAPI后,setTimeout函数本身(但不是回调!)从堆栈中弹出。

image.gif

现在,调用foo,并打印First

image.gif

foo从堆栈弹出,baz被调用,并打印Third

image.gif

WebAPI不能只是在准备就绪时将内容添加到堆栈中。 相反,它将回调函数推送到一个称为任务队列的东西。

image.gif

这是事件循环开始工作的地方。 事件循环查看堆栈和任务队列。 如果堆栈为空,则会占用队列中的第一个内容并将其推送到堆栈中。

image.gif

bar被调用,Second被打印,它从栈中弹出。


31. 单击按钮时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停止冒泡


32. 单击下面的html片段打印的内容是什么?
  <div onclick="console.log('div')">
      <p onclick="console.log('p')">Click here!</p>
    </div>

复制

  • A: p div
  • B: div p
  • C: p
  • D: div
答案: A

如果我们单击p,我们会看到两个日志:pdiv。在事件传播期间,有三个阶段:捕获,目标和冒泡。 默认情况下,事件处理程序在冒泡阶段执行(除非您将useCapture设置为true)。 它从最深的嵌套元素向外延伸。


33. 下面代码的输出是什么?
  const person = { name: 'Lydia' }
      function sayHi(age) {
        console.log(`${this.name} is ${age}`)
      }
      sayHi.call(person, 21)
      sayHi.bind(person, 21)

复制

  • A: undefined is 21 Lydia is 21
  • B: function function
  • C: Lydia is 21 Lydia is 21
  • D: Lydia is 21 function
答案: D

使用两者,我们可以传递我们想要this关键字引用的对象。 但是,.call方法会立即执行!

.bind方法会返回函数的拷贝值,但带有绑定的上下文! 它不会立即执行。


34. 下面代码的输出是什么?
 function sayHi() {
        return (() => 0)()
      }
      typeof sayHi()

复制

  • A: "object"
  • B: "number"
  • C: "function"
  • D: "undefined"
答案: B

sayHi函数返回立即调用的函数(IIFE)的返回值。 该函数返回0,类型为数字

仅供参考:只有7种内置类型:nullundefinedbooleannumberstringobjectsymbolfunction不是一个类型,因为函数是对象,它的类型是object


35. 下面这些值哪些是假值?
0;new Number(0);("");(" ");new Boolean(false);undefined;

复制

  • A: 0, '', undefined
  • B: 0, new Number(0), '', new Boolean(false), undefined
  • C: 0, '', new Boolean(false), undefined
  • D: 所有都是假值
答案: A

JavaScript中只有6个假值:

  • undefined
  • null
  • NaN
  • 0
  • '' (empty string)
  • false

函数构造函数,如new Numbernew Boolean都是真值。


36. 下面代码的输出是什么?
console.log(typeof typeof 1);

复制

  • A: "number"
  • B: "string"
  • C: "object"
  • D: "undefined"
答案: B

typeof 1 返回 "number". typeof "number" 返回 "string"


37. 下面代码的输出是什么?
   const numbers = [1, 2, 3]
      numbers[10] = 11
      console.log(numbers)

复制

  • A: [1, 2, 3, 7 x null, 11]
  • B: [1, 2, 3, 11]
  • C: [1, 2, 3, 7 x empty, 11]
  • D: SyntaxError
答案: C

When you set a value to an element in an array that exceeds the length of the array, JavaScript creates something called "empty slots". These actually have the value of undefined, but you will see something like:

当你为数组中的元素设置一个超过数组长度的值时,JavaScript会创建一个名为“空插槽”的东西。 这些位置的值实际上是undefined,但你会看到类似的东西:

[1, 2, 3, 7 x empty, 11]

这取决于你运行它的位置(每个浏览器有可能不同)。


38. 下面代码的输出是什么?
  ;(() => {
        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作用域的。

之后,我们将这个块级作用域的变量设置为1,并设置变量y的值。 现在,我们打印块级作用域的变量x,它等于1

catch块之外,x仍然是undefined,而y2。 当我们想在catch块之外的console.log(x)时,它返回undefined,而y返回2


39. JavaScript中的所有内容都是…
  • A:原始或对象
  • B:函数或对象
  • C:技巧问题!只有对象
  • D:数字或对象
答案: A

JavaScript只有原始类型和对象。

原始类型是booleannullundefinedbigintnumberstringsymbol


40. 下面代码的输出是什么?
[[0, 1], [2, 3]].reduce(  (acc, cur) => {    return acc.concat(cur);  },  [1, 2]);

复制

  • A: [0, 1, 2, 3, 1, 2]
  • B: [6, 1, 2]
  • C: [1, 2, 0, 1, 2, 3]
  • D: [1, 2, 6]
答案: C

[1,2]是我们的初始值。 这是我们开始执行reduce函数的初始值,以及第一个acc的值。 在第一轮中,acc[1,2]cur[0,1]。 我们将它们连接起来,结果是[1,2,0,1]

然后,acc的值为[1,2,0,1]cur的值为[2,3]。 我们将它们连接起来,得到[1,2,0,1,2,3]


41. 下面代码的输出是什么?
!!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


42. setInterval方法的返回值什么?
setInterval(() => console.log("Hi"), 1000);

复制

  • A:一个唯一的id
  • B:指定的毫秒数
  • C:传递的函数
  • D:undefined
答案: A

它返回一个唯一的id。 此id可用于使用clearInterval()函数清除该定时器。


43. What does this return?
[..."Lydia"];

复制

  • A: ["L", "y", "d", "i", "a"]
  • B: ["Lydia"]
  • C: [[], "Lydia"]
  • D: [["L", "y", "d", "i", "a"]]
答案: A

字符串是可迭代的。 扩展运算符将迭代的每个字符映射到一个元素。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

43道JavaScript面试题 的相关文章

  • Chart.js 在初始化时设置活动段

    我正在使用 Chart js v2 并且尝试在加载图表时模拟圆环图上某个段的 悬停状态 因此看起来有一个部分已突出显示 我已经搜索和梳理了代码一天 但找不到一个好的方法来做到这一点 提前致谢 设置片段的悬停样式有点令人困惑 因为它没有真正记
  • socket.io 的良好初学者教程? [关闭]

    就目前情况而言 这个问题不太适合我们的问答形式 我们希望答案得到事实 参考资料或专业知识的支持 但这个问题可能会引发辩论 争论 民意调查或扩展讨论 如果您觉得这个问题可以改进并可能重新开放 访问帮助中心 help reopen questi
  • Three.js:缩放几何图形后错误的 BoundingBox

    在我的场景中 我有一个简单的立方体 var test new THREE Mesh new THREE CubeGeometry 10 10 10 new THREE MeshBasicMaterial scene add test 该立方
  • 在新的 Google 协作平台 <嵌入 HTML> 中使用 localStorage 和 IndexedDB 不起作用

    我正在尝试将新的 Google 协作平台用于我开发的网页 但是 我在存储本地数据时遇到了问题 本地文件在 Windows 和 Apple safari chrome 中运行良好 从 Google 协作平台尝试一下 没有什么乐趣 此外 在 s
  • 摩卡 - Chai Karma“套件未定义”

    我对 jscript tdd 很陌生 遇到了问题 希望有人能告诉我我在做什么 在浏览器中运行测试 通过 HTML 文件 一切正常 通过节点和业力运行它们我得到以下异常 我想在 node js 主机的 karma 中使用 Mocha 和 Ch
  • 如何针对 Node.js 中发生的每个错误发送电子邮件?

    假设我的 node js 应用程序正在运行 如果出现错误 我的意思是所有错误 不仅仅是网络错误 如果出现错误 则很重要 我如何调用函数向我发送电子邮件 基本上 在我希望它写入 err out 之前 我希望向我发送一封电子邮件 我正在使用no
  • 可以在初始 DOM 解析期间/之前修改 DOM 吗?

    是否可以在初始 DOM 解析期间或之前修改 DOM 或者我是否必须等到 DOM 被解析和构建之后才能与其交互 更具体地说 是否有可能阻止 DOM 中的脚本元素使用用户脚本 内容脚本或 Chrome 或 Firefox 中的类似脚本运行 在解
  • Snap.svg - 停止在可悬停元素的子元素上重新触发悬停事件

    对于一个项目 我使用的 SVG 形状由背景多边形和背景多边形上方的一些文本 我已将其转换为路径 组成 我正在使用 Snap svg 为我的形状设置动画 当我将鼠标悬停在多边形上时 形状应该缩放到特定尺寸 包括其中的所有内容 鼠标移开时 形状
  • Bootstrap按钮加载+Ajax

    我正在使用 Twitter Bootstrap 的按钮加载状态 http twitter github com bootstrap javascript html buttons http twitter github com bootst
  • Angular - CSS - 自定义类型=文件输入,如何使用按钮而不是标签?

    我制作了一个类型为 file 的自定义输入字段 因为我不喜欢默认的输入字段 为了实现这一目标 我做了
  • 将 GMT 时间转换为当地时间

    我以这种格式从我的服务器获取 GMT 时间 Fri 18 Oct 2013 11 38 23 GMT 我的要求是使用Javascript将此时间转换为本地时间 例如 如果用户来自印度 首先我需要采用时区 5 30并将其添加到我的服务器时间并
  • 尝试将数据存储在点击器网站中

    我正在尝试存储一个名为的变量score无论何时刷新 您都会一次又一次地使用它 我不明白的是它的代码是什么 我尝试了一些方法 但似乎都不起作用 这是我的答题器网站 但是当我尝试使用 JavaScript 来存储它时 它不起作用window o
  • 日期出现奇怪的错误,“未捕获非法访问”

    所以我试图找到最新的DateJavascript 可以处理 我把它减少到 9 月 275760 并增加了我开始捕获未捕获的天数illegal access例外new Date 09 24 275760 to new Date 10 13 2
  • 使用 Vue 的多模式组件

    我在 Vue 中实现动态模式组件时遇到问题 A common approach I follow to display a set of data fetched from the db is I dump each of the rows
  • 如何在生产模式下为 Chrome 扩展启用 Vue 开发工具?

    我正在构建一个 chrome 扩展 并使用 vue cli webpack 配置 我希望能够在运行后使用 vue devtoolsnpm 运行构建命令 我尝试添加Vue config devtools true 在 main js 中 或者
  • 如何使用 crypto-js 解密 AES ECB

    我正在尝试将加密数据从 flash 客户端 发送到服务器端的 javascript 在 asp 中作为 jscript 运行 有几个 javascript Aes 库 但它们实际上没有文档记录 我正在尝试使用 crypto js 但无法让代
  • 如何隐藏/禁用 Highcharts.js 中的图例框?

    我想问是否可以使用 HighCharts js 库隐藏图表中的所有图例框 var chart object chart renderTo render to type graph type colors graph colors title
  • 将 CKEditor 5 与 nuxtjs 结合使用

    我正在尝试在我的 Nuxtjs 项目中导入 CKEditor 5 的自定义版本 并且我已经尝试了所有可能的方法来正确导入它 但没有一个对我有用 这是其中之一 let ClassicEditor let CKEditor if process
  • 使用 MongoDB 和 Nodejs 插入和查询日期

    我需要一些帮助在 mongodb 和 nodejs 中按日期查找记录 我将日期添加到抓取脚本中的 json 对象 如下所示 jsonObj last updated new Date 该对象被插入到 mongodb 中 我可以看到如下 la
  • 分页在服务器端好还是前端好? [关闭]

    Closed 这个问题是基于意见的 help closed questions 目前不接受答案 我正在构建 Laravel Vue 应用程序 我想知道在后端使用分页还是在前端使用分页更好 我认为最好在每页发送尽可能少的数据的请求 但我想听听

随机推荐

  • 第一篇 香橙派刷机和开发环境准备(Armbian版)

    目录 一 香橙派刷机和SSH登录 1 格式化TF卡 2 烧写系统到TF卡 3 调试串口登陆系统 4 SSH登陆系统 1 nmcli命令 2 armbian config配置菜单 3 使用Xshell以SSH方式登陆 二 OrangePi开发
  • [灵魂拷问]MySQL面试高频100问(工程师方向)

    黑客技术 点击右侧关注 了解黑客的世界 Java开发进阶 点击右侧关注 掌握进阶之路 Python开发
  • 【chatGPT】让java程序员工作效率翻10倍技巧

    本来写给我自己用来着 想着以后忘记了就分享出来 1 写枚举 对于程序员来说枚举的命名需要大写并且写枚举也是被迫的 大部分人的感受都一样啊喂 所以可以直接用chatgpt偷懒 录入关键字 例 帮我写个java枚举 xxxxx 活动兑奖状态 0
  • Redis 学习笔记(十五)Redis Cluster 集群扩容与收缩

    Redis Cluster 集群伸缩 1 伸缩原理 Redis提供了灵活的节点扩容和收缩方案 在不影响集群对外服务的情况下 可以为集群添加节点进行扩容也可以对下线节点进行缩容 我们在Redis Cluster 介绍与搭建这篇文章中搭建了一个
  • 配置maven 阿里云镜像

    镜像配置为阿里云进项下载速度快 jdk配置为1 8
  • Ubuntu下CodeBlocks的安装、配置及静态库动态库的简单使用举例

    1 从Ubuntu Software Center中搜索Code Blocks并安装 2 在第一次启动时选择GNU GCC Compiler作为默认的编译器 3 生成静态库并调用操作步骤 代码同 http blog csdn net fen
  • 使用FormData对form表单序列化

    一 FormData作用 将form表单元素的name与value进行组合 实现表单数据的序列化 异步上传二进制文件 二 创建formData对象
  • 盲源分离算法

    盲源分离在维基百科的定义 指的是从多个观测到的混合信号中分析出没有观测的原始信号 通常观测到的混合信号来自多个传感器的输出 并且传感器的输出信号独立 线性不相关 盲信号的 盲 字强调了两点 1 原始信号并不知道 2 对于信号混合的方法也不知
  • 模糊神经网络

    介绍 模糊神经网络把神经网络的学习能力引入到模糊系统中 将模糊系统的模糊化处理 模糊推理通过神经网络来表示 一般分为四层 1 输入层 2 模糊化层 3 模糊推理层 4 输出层
  • 计算机视觉 -- 图像分割

    文章目录 1 图像分割 2 FCN 2 1 语义分割 FCN Fully Convolutional Networks 2 2 FCN deconv 2 3 Unpool 2 4 拓展 DeconvNet 3 实例分割 3 1 实例分割 M
  • 思科员工离职恶意删除456个虚拟机,造成240w美元直接损失,或面临5年有期徒刑

    删库跑路一直是程序员用来业余调侃的开玩笑之举 没想到的是 近日一名叫Ramesh的思科前员工竟真的就干起了这事 目前该员工已于周三上午在圣何塞联邦法院认罪 供认非法访问了思科的AWS基础架构 并破坏了大量云计算资源 根据检察官的说明 Ram
  • C语言函数大全-- k 开头的函数

    k 开头的函数 1 kcalloc 1 1 函数说明 1 2 演示示例 2 kbhit 2 1 函数说明 2 2 演示示例 2 3 运行结果 3 keep 3 1 函数说明 3 2 演示示例 4 kernel thread 4 1 函数说明
  • LW-基于知识图谱的专利推荐系统设计与实现(分类号:TP311 单位代码:10422)观后总结

    论文的主要工作以基于知识图谱的专利推荐为主题 从研究背景和意义 国内外研究现状 用户需求分析 系统概要设计 核心算法设计 系统详细设计以及系统实现与测试等几个方面对基于知识图谱的专利推荐系统进行详细描述 第 章 绪论 1 1 背景和意义 传
  • 命悬一线小游戏

    欢迎来到程序小院 命悬一线 玩法 点击鼠标人物摆动跳跃 松开鼠标跳到方格上面 每跳一次都会有对应的分数统计 不要让人物掉下哦 开始游戏 html
  • 科大讯飞编程题 2018 课程冲突

    科大讯飞编程题 发布于 今天 16 34 1695 次浏览 0 赞 来自 我要提问 科大讯飞 2018校招 技术综合方向试卷在线考试 编程题 20 0分3 3 课程冲突 时间限制 C C 语言 2000MS 其他语言 4000MS 内存限制
  • Pycharm连接MySQL后出现不出现数据库或表,出现其他文件的问题

    在使用pycharm连接MySQL 配置完成 测试连接通过之后 还是不能显示数据库中的表 出现了许多像armscii8 bin armscii8 general ci和ascii bin等的文件 解决方法是 回到数据库设置页面 在Schem
  • .NET6 using

    在 net 6 的应用程序中 using 语句去了哪里 net 5 中 using 语句直接写在文件顶端就可以了 但是在 net 6 中 main函数被隐式的执行 文件最顶部也找不到 using 指令了 找了找其他文件 发现在obj gt
  • WebSocket connection to 'ws://xxxxxx/ws/' failed: Unexpected response code: 502

    在使用reactJs开发一个项目的时候在适配Android的时候遇到这个问题 首先 前提是这个webscoket地址是可以使用的 并且在电脑浏览器上是可以正常的 其次 Android7 0以上的原生浏览器上是正常的 国内其他机型自带浏览器不
  • CentOS7 创建用户及更改其属组与属主(账户管理与权限)

    CentOS 7 是一个广泛使用的 Linux 发行版 基于源代码 Red Hat Enterprise Linux RHEL 它以其稳定性 安全性和长期支持而闻名 以下是 CentOS 7 的一些主要功能 1 内核 CentOS 7 使用
  • 43道JavaScript面试题

    1 下面代码的输出是什么 function sayHi console log name console log age var name Lydia let age 21 sayHi 复制 A Lydia 和 undefined B Ly