31. 当点击按钮时,event.target是什么?

<div onclick="console.log('first div')">
  <div onclick="console.log('second div')">
    <button onclick="console.log('button')">
      Click!
    </button>
  </div>
</div>

155个JavaScript基础问题(31-40)_字面量

答:C,触发事件的对象的引用是button.

32. 单击该段落时,输出是什么?

<div onclick="console.log('div')">
  <p onclick="console.log('p')">
    Click here!
  </p>
</div>

155个JavaScript基础问题(31-40)_事件冒泡_02

答:A,本题考查的是事件冒泡。

33. 输出是什么?

const person = { name: 'Lydia' }

function sayHi(age) {
  console.log(`${this.name} is ${age}`)
}

sayHi.call(person, 21)
sayHi.bind(person, 21)

155个JavaScript基础问题(31-40)_javascript_03

答:D,本题之所以选D的原因在于,call是立即执行的,bind返回一个函数。

34. 输出是什么?

function sayHi() {
  return (() => 0)()
}

typeof sayHi()

155个JavaScript基础问题(31-40)_事件冒泡_04

答:B,这是因为sayHi函数返回的是一个立即执行函数的结果,所以返回的是0,0属于number类型的。

35. 下面哪些值是假值?

0
new Number(0)
('')
(' ')
new Boolean(false)
undefined

155个JavaScript基础问题(31-40)_技术_05

答:A,首先我们要明确一点,new Number和new Boolean都不是字面量了,而是一个对象,所以他们不等价于假值,’’ 和 ’ '这两个也不一样,一个是空串可以表示假值,但是另一个是空格,不代表假值,所以本题选A。155个JavaScript基础问题(31-40)_技术_06

36. 输出是什么?

console.log(typeof typeof 1)

155个JavaScript基础问题(31-40)_javascript_07

答:B,这题有点坑,是因为typeof 1返回的是字符串 “number”,这也就是为什么再次typeof返回的是string了。

37. 输出是什么?

const numbers = [1, 2, 3]
numbers[10] = 11
console.log(numbers)

155个JavaScript基础问题(31-40)_事件冒泡_08

答:C,当给超过数组长度的位置设置值的时候,其实中间都是undefined,打印出来就像下面这样。155个JavaScript基础问题(31-40)_事件冒泡_09

38. 输出是什么?

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

155个JavaScript基础问题(31-40)_技术_10

答:A,这道题主要是想考察catch会形成一个块级作用域,catch中接收到的x和let 定义的x不是同一个,但是catch中操作的y是同一个,这也就是为什么返回的是1 undefined 2的原因了。

39. JavaScript中的一切都是什么?

155个JavaScript基础问题(31-40)_技术_11

答:A,这道题我原本想选C来着,但是仔细想想单纯的字面量必须要归为一类。

40. 输出是什么?

[[0, 1], [2, 3]].reduce(
  (acc, cur) => {
    return acc.concat(cur)
  },
  [1, 2]
)

155个JavaScript基础问题(31-40)_字面量_12

答:C,这题没有什么坑,关键就是看清一点,使用reduce之前给了初始值[1,2].

题目来源

https://github.com/lydiahallie/javascript-questions

欢迎大家批评指针,共同努力,共同进步!