6
头图

大家好我是林三心,又一周过去了,哎,想想年纪又大了,就烦。今天突然有人问我:

(a == 1 && a == 2 && a ==3) 有可能是 true 吗

我当时就想一脚踹过去,你这不是在耍我吗?当我的脚离他的脸一厘米时,我突然发现,诶!好像有点意思哦

对象类型转换

当两个类型不同时进行==比较时,会将一个类型转为另一个类型,然后再进行比较。 比如Object类型与Number类型进行比较时,Object类型会转换为Number类型。 Object转换为Number时,会尝试调用Object.valueOf()Object.toString()来获取对应的数字基本类型。
var a = {
    i: 1,
    toString: function () {
        return a.i++;
    }
}
console.log(a == 1 && a == 2 && a == 3) // true

数组类型转换

与上面这个类型转换一样,数组调用toString()会隐含调用Array.join()方法 而数组shift方法的用法:shift() 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值。如果数组是空的,那么 shift() 方法将不进行任何操作,返回 undefined 值。请注意,该方法不创建新数组,而是直接修改原有的 数组。 所以我们可以看到 a == 1时会调用toString(),toString()调用join()join()等于shift,则转换为Number类型后为1.
var a = [1, 2, 3];
a.join = a.shift;
console.log(a == 1 && a == 2 && a == 3); // true

defineProperty

使用一个defineProperty,让 a 的返回值为三个不同的值。
var val = 0;
Object.defineProperty(window, 'a', { // 这里要window,这样的话下面才能直接使用a变量去 ==
    get: function () {
        return ++val;
    }
});
console.log(a == 1 && a == 2 && a == 3) // true
你学废了吗?

结语

我是林三心,一个热心的前端菜鸟程序员。如果你上进,喜欢前端,想学习前端,那咱们可以交朋友,一起摸鱼哈哈,摸鱼群,加我请备注【思否】

image.png


Sunshine_Lin
2.1k 声望7.1k 粉丝