Why does javascript's “in” operator return true when testing if 0 exists in an array that doesn't contain 0?

Deadly 提交于 2019-11-26 03:58:00

问题


Why does the \"in\" operator in Javascript return true when testing if \"0\" exists in array, even when the array doesn\'t appear to contain \"0\"?

For example, this returns true, and makes sense:

var x = [1,2];
1 in x; // true

This returns false, and makes sense:

var x = [1,2];
3 in x; // false

However this returns true, and I don\'t understand why:

var x = [1,2];
0 in x;

回答1:


It refers to the index or key, not the value. 0 and 1 are the valid indices for that array. There are also valid keys, including "length" and "toSource". Try 2 in x. That will be false (since JavaScript arrays are 0-indexed).

See the MDN documentation.




回答2:


The in operator doesn't do what you're thinking it does. The in operator returns true if the specified operand is a property of the object. For arrays, it returns true if the operand is a valid index (which makes sense if think of arrays as a special-case object where the properties are simply named 0, 1, 2, ...)

For example, try this:

javascript:var x=[1,4,6]; alert(2 in x);

It'll also return true, because "2" is a valid index into the array. In the same way, "0" is an index into the array, so also returns true.




回答3:


Javascript's in operator does not check if a value is contained in an array. It checks if the object has a property or index. So var x = [4,5]; 4 in x; //false 1 in x; //true.

Because length is a property of x, "length" in x; //true




回答4:


Modern browsers, except IE, support a couple methods that can find a value in an array.

indexOf and lastIndexOf return the first(or last) index of an exact match of their argument in an array, or -1, if no matching element was found.

if(A.indexOf(0)!= -1){
    // the array contains an element with the value 0.
}

You can add one or both methods to IE and older browsers-

if(![].indexOf){
    Array.prototype.indexOf= function(what, i){
        i= i || 0;
        var L= this.length;
        while(i< L){
            if(this[i]=== what) return i;
            ++i;
        }
        return -1;
    }
    Array.prototype.lastIndexOf= function(what, i){
        var L= this.length;
        i= i || L-1;
        if(isNaN(i) || i>= L) i= L-1;
        else if(i< 0) i += L;
        while(i> -1){
            if(this[i]=== what) return i;
            --i;
        }
        return -1;
    }
}



回答5:


just like the js for in loop which iterates the object properties, the in operator checks if the specified property is in the specified object or its prototype chain. it does not check whether an element is in an array.

let's say x is an array, use x.includes(element) to return true/false in nodejs/modern-browsers. As for loop, use for(let element of x) since x is a js iterable.




回答6:


I guess you use Python before, in JS, use Array.prototype.includes

let x = [1, 2]
x.includes(1) // true


来源:https://stackoverflow.com/questions/3067072/why-does-javascripts-in-operator-return-true-when-testing-if-0-exists-in-an-a

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!