【数组】array.indexOf(item,start)

125 阅读1分钟

一、字符串或数字

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

结论:两个相同的对象和两个相同的数组不一定相等,除非引用相同并且元素相同。