JS indexOf 用法

1.Array.indexOf()方法返回在数组中可以找到一个给定元素的第一个索引,如果不存在,则返回-1。

语法:arr.indexOf(searchElement[, fromIndex])

参数:

searchElement:需要查招的元素

fromIndex:开始查找的位置。如果该索引值大于或等于数组长度,意味着不会在数组里查找,返回-1。如果参数中提供的索引值是一个负值,则将其作为数组末尾的一个抵消,即-1表示从最后一个元素开始查找,-2表示从倒数第二个元素开始查找 ,以此类推。 注意:如果参数中提供的索引值是一个负值,并不改变其查找顺序,查找顺序仍然是从前向后查询数组。如果抵消后的索引值仍小于0,则整个数组都将会被查询。其默认值为0.

返回值:首个被找到的索引位置,如果找不到则返回-1

例子:

let arr = [1,2,3,4,5,4,3,2,1];

console.log(arr.indexOf(1)); // 没有填fromIndex所以默认从索引为0的位置开始往后查找
// 0
console.log(arr.indexOf(1,1)); // 表示从索引为1的位置开始往后查找
// 8

案例:利用indexOf实现数组去重

// 想要的结果是[1,2,3,4,5]
let arr = [1, 2, 3, 1, 2, 4, 5];
// 利用arr.filter遍历出arr数组里的所有值和相对索引
let newArr = arr.filter(function (value, index, step) {
    // 判断他第一次出现的位置是不是当前索引,是的话返回给newArr
    return step.indexOf(value) == index;
});
console.log(newArr);
// [1,2,3,4,5]

 扩展:上面代码中的filter的使用:点击查看

2.String.indexOf() 方法返回调用它的 String 对象中第一次出现的指定值的索引,如果不存在,则返回-1。

语法:str.indexOf(searchElement[, fromIndex])

参数:

searchStr:需要查招的字符

fromIndex:开始查找的位置。如果该索引值大于或等于数组长度,意味着不会在数组里查找,返回-1。如果参数中提供的索引值是一个负值,则将其作为数组末尾的一个抵消,即-1表示从最后一个元素开始查找,-2表示从倒数第二个元素开始查找 ,以此类推。 注意:如果参数中提供的索引值是一个负值,并不改变其查找顺序,查找顺序仍然是从前向后查询数组。如果抵消后的索引值仍小于0,则整个数组都将会被查询。其默认值为0.

返回值:首个被找到的索引位置,如果找不到则返回-1

例子:

let str = 'abcdcba';

console.log(str.indexOf('a')); // 没有填fromIndex所以默认从索引为0的位置开始往后查找
// 0
console.log(str.indexOf('a',1)); // 表示从索引为1的位置开始往后查找
// 6

str.indexOf有一个奇怪的现象,当searchStr是一个空字符串的时候,他会返回fromIndex的值,比如fromIndex不填的时候他默认是0,他返回的结果就是0。

如果fromIndex的值是他本身的长度还是大于他,他都会返回他本身的length,直接看代码

let str = 'abcdcba';

console.log(str.indexOf(''));
// 0
console.log(str.indexOf('',0));
// 0
console.log(str.indexOf('',3));
// 3
console.log(str.indexOf('',str.length));
// 7
console.log(str.indexOf('',100));
// 7

案例:屏蔽关键是:wc

let str = 'on tow wc tow wc on';
let k = 'wc';
while (str.indexOf(k) != -1){
    str = str.replace(k,'*' * k.length);
}
console.log(str);
// on tow * tow * on

扩展:str.replace的使用

  • 8
    点赞
  • 53
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在JavaScript中,indexOf函数用于查找数组中某个元素的索引。但是需要注意的是,indexOf函数是严格区分大小写的,也就是说无法同时进行大小写匹配。所以,在使用indexOf函数时,需要确保要查找的元素与数组中的元素大小写一致。 在你提供的代码中,arr是一个包含两个对象的数组,而obj是一个单独的对象。当你使用arr.indexOf(obj)时,由于数组中的对象与obj并不是同一个引用,所以返回的结果是-1,表示在数组中未找到匹配的元素。 如果你想实现大小写不敏感的indexOf函数,你可以自定义一个函数来实现。比如你提供的myIndexOf函数,它通过使用JSON.stringify将对象转换为字符串,并将字符串进行比较来确定元素是否匹配。这样可以实现在数组中查找对象时忽略大小写的功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [js indexOf 的正确用法](https://blog.csdn.net/qq_44603011/article/details/122622083)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [JavaScript indexOf忽略大小写](https://download.csdn.net/download/weixin_38520437/13074640)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值