我的页面上有这个array.prototype,似乎在浪费很多处理时间:

        Array.prototype.findInArray = function(searchStr) {
          var returnArray = false;
          for (i=0; i<this.length; i++) {
            if (typeof(searchStr) == 'function') {
              if (searchStr.test(this[i])) {
                if (!returnArray) { returnArray = [] }
                returnArray.push(i);
              }
            } else {
              var regexp = new RegExp(".*" + searchStr + ".*");
              if (this[i].match(regexp)) {
                if (!returnArray) { returnArray = [] }
                returnArray.push(i);
              }
            }
          }
          return returnArray;
        }

最佳答案

首先,您知道不必两边都有“。*”,对吗?默认情况下,正则表达式将匹配字符串内的任何位置。其次,如果您只是在搜索常量字符串,而无需使用正则表达式提供的任何高级功能,那么使用.indexOf()肯定会更快。再加上这种方式,您不必担心转义具有特殊含义的字符。

10-07 17:05