2

我在代码库中遇到过这段代码来添加 indexOf 函数:

if (!Array.prototype.indexOf)
{
  Array.prototype.indexOf = function(elt /*, from*/)
  {
    var len = this.length >>> 0;

    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;
  };
}

这是与 Mozilla https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array/indexOf推荐的不同的实现:

代码:

   if (!Array.prototype.indexOf) {  
        Array.prototype.indexOf = function (searchElement /*, fromIndex */ ) {  
            "use strict";  
            if (this == null) {  
                throw new TypeError();  
            }  
            var t = Object(this);  
            var len = t.length >>> 0;  
            if (len === 0) {  
                return -1;  
            }  
            var n = 0;  
            if (arguments.length > 0) {  
                n = Number(arguments[1]);  
                if (n != n) { // shortcut for verifying if it's NaN  
                    n = 0;  
                } else if (n != 0 && n != Infinity && n != -Infinity) {  
                    n = (n > 0 || -1) * Math.floor(Math.abs(n));  
                }  
            }  
            if (n >= len) {  
                return -1;  
            }  
            var k = n >= 0 ? n : Math.max(len - Math.abs(n), 0);  
            for (; k < len; k++) {  
                if (k in t && t[k] === searchElement) {  
                    return k;  
                }  
            }  
            return -1;  
        }  
    }  

我应该使用 Mozilla 版本还是问题开头提到的版本就足够了?使用其中一种是否有优势?

4

2 回答 2

2

我建议在 indexOf 上使用 Mozilla 版本。它与第一个实现非常相似,但更加精致(实际上这并不奇怪)。例如,当它发现给定数组为空时,它会正确返回 -1,并且会正确处理作为第二个参数给出的不同边缘值。

或者更好的是,如果您使用 jQuery(正如您选择的标签所暗示的那样),为什么不直接使用它的$.inArray()方法呢?

于 2012-06-22T16:22:31.893 回答
2

它们都来自 MDN,但第一个版本来自indexOf页面的旧版本。较新的版本是为了使实现符合 ECMAScript 5 规范中发布的算法的更新。鉴于所有这些,使用较新版本似乎是合理的。

这是 MDN 页面上进行更改的差异:

https://developer.mozilla.org/index.php?title=en/JavaScript/Reference/Global_Objects/Array/indexOf&action=diff&revision=32&diff=33

于 2012-06-22T16:36:54.040 回答