题目信息
问题1:浏览器控制台上会打印什么? 答案(JS 常见问题)
var a = 10; function foo() { console.log(a); // ?? var a = 20; } foo();
问题2:如果我们使用 let 或 const 代替 var,输出是否相同 答案(JS 常见问题)
var a = 10; function foo() { console.log(a); // ?? let a = 20; } foo();
问题3:"newArray"中有哪些元素? 答案(JS 常见问题)
var array = []; for(var i = 0; i <3; i++) { array.push(() => i); } var newArray = array.map(el => el()); console.log(newArray); // ??
问题4:如果我们在浏览器控制台中运行'foo'函数,是否会导致堆栈溢出错误? 答案(JS 常见问题)
function foo() { setTimeout(foo, 0); // 是否存在堆栈溢出错误? };
问题5: 如果在控制台中运行以下函数,页面(选项卡)的 UI 是否仍然响应 答案(JS 常见问题)
function foo() { return Promise.resolve().then(foo); };
问题6: 我们能否以某种方式为下面的语句使用展开运算而不导致类型错误 答案(JS 常见问题)
var obj = { x: 1, y: 2, z: 3 }; [...obj]; // TypeError
问题7:运行以下代码片段时,控制台上会打印什么? 答案(JS 常见问题)
var obj = { a: 1, b: 2 }; Object.setPrototypeOf(obj, {c: 3}); Object.defineProperty(obj, 'd', { value: 4, enumerable: false }); // what properties will be printed when we run the for-in loop? for(let prop in obj) { console.log(prop); }
问题8:xGetter() 会打印什么值? 答案(JS 常见问题)
var x = 10;
var foo = {
x: 90,
getX: function() {
return this.x;
}
};
foo.getX(); // prints 90
var xGetter = foo.getX;
xGetter(); // prints ??