RT
在书上看见这个例子
var person={name:"Nicholas"};
var people=[{name:"Nicholas"}];
var morepeople=[person];
alert(people.indexOf(person));// -1
alert(morepeople.indexOf(person));// 0
有点不明白 为何alert(people.indexOf(person));
会得到 -1
RT
在书上看见这个例子
var person={name:"Nicholas"};
var people=[{name:"Nicholas"}];
var morepeople=[person];
alert(people.indexOf(person));// -1
alert(morepeople.indexOf(person));// 0
有点不明白 为何alert(people.indexOf(person));
会得到 -1
indexOf 的比较就是单纯的 ===。
我把你的问题简化一下,可以看下面的例子:
var x = {a:1};
var y = {a:1};
console.log(x === y); //输出false
因为x,y并不是同一个对象,只是恰好有一个同名属性,且值相同。(但两个对象在内存中不是同一个对象)
只要知道一个对象只等于它自己就好了
。
10 回答11.2k 阅读
5 回答4.9k 阅读✓ 已解决
4 回答3.1k 阅读✓ 已解决
2 回答2.8k 阅读✓ 已解决
3 回答2.4k 阅读✓ 已解决
3 回答2.2k 阅读✓ 已解决
2 回答2.6k 阅读✓ 已解决
我去看了一下那本书,首先你的代码有一个地方错了。
morepeople = [person]
这样才对。在这里查找的时候,所比较的是对象。
在
people
这个数组中的这个{name:"Nicholas"}
和 person 并不是同一个对象,而morepeole
中和person
是同一个对象(因为直接引用了它)。因此第一个会返回
-1
(无法找到),第二个是0
。你可以直接进行测试,
person == people[0]
或者person === people[0]
都是不成立的(false
)。