一、字符串或数字
let food= ["番茄", "胡萝卜", "苹果"];
let a = food.indexOf("苹果");
console.log(a) // 2
let b= food.indexOf("香蕉");
console.log(b) // -1
array.indexOf(item,start)
item 必须传。代表要查找的元素的位置;
start 非必须可选的整数参数。规定在数组中开始检索的位置。它的合法取值是 0 到stringObject.length - 1。如省略该参数,则将从字符串的首字符开始检索。
let str="Hello world!";
console.log(str.indexOf("Hello"));//0
console.log(str.indexOf("World"));//-1
console.log(str.indexOf("world"));//6
- 区分大小写
- 如果要检索的字符串值没有出现,则该方法返回 -1。
二、数组对象
const arr = [{age:'1',name:'2'}, {age:'3', name:'4'}]
arr.indexOf({age:'1',name:'2'})
-1
const obj1 = arr[0]
arr.indexOf(obj1)
0
由上述代码可以知道,其实indexOf查找相同地址的对象,所以对于地址不同的对象是查不到的,如果是和数组内部对象指向同一地址,则可以拿到,否则就拿不到。
{name:'xm'} !== {name:'xm'}
true
const obj1 = arr[0]
const obj2 = arr[0]
obj1 !== obj2
false
const obj3 = {'age':1, name:'2'}
const obj4 = {'age':1, name:'2'}
obj3 == obj4
false
obj5 = obj3
obj3 == obj5
true
obj3 === obj5
true
对象之间的==和===都是比较的地址,地址不同的对象即使属性完全相同也是返回false。
let a = [[1,3], [2,4], [2,3]]
let b = [2,4]
let c = a.indexOf(b)
输出:c = -1
结论:两个相同的对象和两个相同的数组不一定相等,除非引用相同并且元素相同。