Javascript 中的 indexOf()函数

首页 / JavaScript入门教程 / Javascript 中的 indexOf()函数

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

indexOf() - 语法

array.indexOf(searchElement[, fromIndex]);

indexOf() - 返回值

返回找到的元素的索引。

indexOf() - 相容性

此方法是ECMA-262标准的JavaScript扩展;因此,它可能不存在于该标准的其他实现中。要使其工作,您需要在脚本顶部添加以下代码。

if (!Array.prototype.indexOf) {
   Array.prototype.indexOf=function(elt /*, from*/) {
      var len=this.length;
      
      var from=Number(arguments[1]) || 0;
      from=(from < 0)
      ? Math.ceil(from)
      : Math.floor(from);
      
      if (from < 0)
      from += len;
      
      for (; from < len; from++) {
         if (from in this &&amp
         this[from] === elt)
         return from;
      }
      return -1;
   };
}

indexOf() - 示例

<html>
   <head>
      <title>JavaScript Array indexOf Method</title>
   </head>
   
   <body>   
      <script type="text/javascript">
         if (!Array.prototype.indexOf) {
            Array.prototype.indexOf=function(elt /*, from*/) {
               var len=this.length;
               
               var from=Number(arguments[1]) || 0;
               from=(from < 0)
               ? Math.ceil(from)
               : Math.floor(from);
               
               if (from < 0)
               from += len;
               
               for (; from < len; from++) {
                  if (from in this &&
                  this[from] === elt)
                  return from;
               }
               return -1;
            };
         }
         var index=[12, 5, 8, 130, 44].indexOf(8);
         document.write("index is : " + index ); 
         
         var index=[12, 5, 8, 130, 44].indexOf(13);
         document.write("<br />index is : " + index ); 
      </script>      
   </body>
</html>

运行上面代码输出

index is : 2
index is : -1 

祝学习愉快!(内容编辑有误?请选中要编辑内容 -> 右键 -> 修改 -> 提交!)

技术教程推荐

技术管理实战36讲 -〔刘建国〕

算法面试通关40讲 -〔覃超〕

程序员的数学基础课 -〔黄申〕

玩转webpack -〔程柳锋〕

数据中台实战课 -〔郭忆〕

跟月影学可视化 -〔月影〕

动态规划面试宝典 -〔卢誉声〕

技术面试官识人手册 -〔熊燚(四火)〕

结构思考力 · 透过结构看思考 -〔李忠秋〕

好记忆不如烂笔头。留下您的足迹吧 :)