JS面试题集锦及解析(个人向)

1 、

var a=10;
function test(){
    a=100;
    console.log(a);
    console.log(this.a);
    var a;
    console.log(a);
}
test();

//输出: 100 10 100

这道题目是考察对变量声明提升的理解 和 this关键字的指向性问题。

首先是变量提升,在JS中,使用var声明的变量会被提升到当前词法作用域的顶部,函数在编译时变成了这样

var a=10;
function test(){
    var a;
    a=100;
    console.log(a);
    console.log(this.a);
    console.log(a);
}
test();

这样子就清晰了,第一次打印时,函数内部声明了一个a,是100,第二次log时,因为函数是直接调用的,window.test()谁调用this就指向谁,所以是window.a结果是10.

2、下题输出什么?

(function(){
  var a = b = 3;
})();

console.log(a) //报错a is not defined
console.log(b) //输出3

这里面的声明语句很容易被误解为是 var a = 3,var b = 3.实际上并不是这样,而是这样。

b = 3;
var a = b;

a 在局部作用域里用var 关键字声明,所以是一个局部变量,在函数外面接受不到,所以会报错。

而 b 是没有var声明,就是this下的一个属性. this.b .所以在外面能访问到

3、

'a' + + 'b' // -> "aNaN"
// 因为 + 'b' -> NaN
// 你也许在一些代码中看到过 + '1' -> 1

4、[] == ![]

[] == ![] // -> true

//下面是分析
// [] 转成 true,然后取反变成 false
[] == false
// 将Boolen值转换为数字
[] == 0
// 将对象转化为字符串
// [].toString() -> ''
'' == 0
// 将字符串转化为数字
0 == 0 // -> true

在JS中 == 是会进行隐式转换的

执行类型转换的规则如下:
如果一个运算数是 Boolean 值,在检查相等性之前,把它转换成数字值。false 转换成 0,true 为 1。
如果一个运算数是字符串,另一个是数字,在检查相等性之前,要尝试把字符串转换成数字。
如果一个运算数是对象,另一个是字符串,在检查相等性之前,要尝试把对象转换成字符串。
如果一个运算数是对象,另一个是数字,在检查相等性之前,要尝试把对象转换成数字。
在比较时,该运算符还遵守下列规则:
值 null 和 undefined 相等。
在检查相等性时,不能把 null 和 undefined 转换成其他值。
如果某个运算数是 NaN,等号将返回 false,非等号将返回 true。
如果两个运算数都是对象,那么比较的是它们的引用值。如果两个运算数指向同一对象,那么等号返回 true,否则两个运算数不等。
5、你知道哪些CSS伪类?

:link, :hover,:enabled,:disabled,:checked,:not(selector) 

在这里我随便列举几个,其实还有很多,在文档资料里都能查得到 https://developer.mozilla.org/zh-CN/docs/Web/CSS/Pseudo-classes

这题要注意的其实是伪类和伪元素(::after)的区别

推荐一篇文章:CSS3伪类与伪元素的区别及注意事项

6、下面输出什么

function a () {
    return 
    {
        a: 'hello'
    }
}
// 输出: undefined

为什么输出undefined

因为return后面的换行会被规则转为分号

MDN资料:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Statements/return

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值