26. 以下JavaScript代码行将输出什么到控制台?
console.log(“0 || 1 =”+(0 || 1));
console.log(“1 || 2 =”+(1 || 2));
console.log(“0 && 1 =”+(0 && 1));
console.log(“1 && 2 =”+(1 && 2));

面试通过率:33.0%
推荐指数: ★★★★ 试题难度: 高难 试题类型: 编程题

// 1// 1// 0// 2

27. 下面的JavaScript代码将输出什么?请解释
console.log(false == ‘0’)
console.log(false === ‘0’)

面试通过率:77.0%
推荐指数: ★★★★ 试题难度: 中级 试题类型: 编程题

// true// false

28. 解释如下JavaScript代码将输出什么?解释你的答案
var a={}, b={key: ‘b’}, c={key: ‘c’};
a[b]=123;
a[c]=456;
console.log(a[b]);

面试通过率:70.0%
推荐指数: ★★★ 试题难度: 初级 试题类型: 编程题

// 456JavaScript会隐式地将[ ]内的变量转换成字符串,b和c 中存储的都是对各自对象的对象引用,对象引用转化为字符串,都会变为'[object Object]'
  1. JavaScript 执行这段代码,输出什么结果 ?
function test() {console.log(a);console.log(foo());var a = 1;function foo() {return 2;}}test();
 面试通过率:53.0%

推荐指数: ★★★★ 试题难度: 中级 试题类型: 编程题

// undefinedvar声明的变量具有变量提升// 2函数提升
  1. 考核this在JavaScript中如何工作的?
    下面的代码会输出什么结果?给出你的答案。
var fullname = 'John Doe';var obj = {fullname: 'Colin Ihrig',prop: {fullname: 'Aurelio De Rosa',getFullname: function() {return this.fullname;}}};console.log(obj.prop.getFullname());var test = obj.prop.getFullname;console.log(test());
面试通过率:72.0%

推荐指数: ★★★★ 试题难度: 中级 试题类型: 编程题

答案是Aurelio De Rosa和John Doe。原因是,在一个函数中,this的行为,取决于JavaScript函数的调用方式和定义方式,而不仅仅是看它如何被定义的。在第一个 console.log()调用中,getFullname()被调用作为obj.prop对象的函数。所以,上下文指的是后者,函数返回该对象的 fullname。与此相反,当getFullname()被分配到test变量时,上下文指的是全局对象(window)。这是因为test是被隐式设置为全局对象的属性。出于这个原因,该函数返回window的fullname,即定义在第一行的那个值