2

我正在尝试使用PURE JAVASCRIPT检查数组中的匹配项。我不知道该怎么做,我会感谢你的帮助。

var sites = new Array ("site1.com", "site2.com", "site3.com" ...);
// Sites array contains 100 values

var imgs = document.getElementsByTagName("img");
    for (var i = 0; i < imgs.length; i++) {
        img = imgs[i].src;

        // I'm trying to check if is in array, 
        // and don't waste a lot of size in code

        if(img.match(sites)){
            notHere(imgs[i]);
        }

        // This is the working way.
        // Even if location is a.site1.com/b/, it will match 
        if (img.match("site1.com")) {
            heReload(imgs[i]);
        }
        // Repeat this piece of code 100 times
    }
}

注意:我不想检查确切的值。我想模拟这个match()函数,所以如果 img = "http://abc/d/" 并且在数组中是 "bc/",它会执行function()

4

3 回答 3

1

过滤器的好用例。

如果您想让它在“旧”浏览器上运行:

var nativeFilter = Array.prototype.filter;
_.filter = _.select = function(obj, iterator, context) {
    var results = [];
    if (obj == null) return results;
    if (nativeFilter && obj.filter === nativeFilter) return obj.filter(iterator, context);
    each(obj, function(value, index, list) {
      if (iterator.call(context, value, index, list)) results[results.length] = value;
    });
    return results;
};

如果没有找到,它将返回一个空数组,否则,返回一个包含结果的数组

> [1,2,3,4].filter(function(item) { return item == 4 } );
[ 4 ]

来源:Underscore.js

所以现在您的代码将如下所示:

var sites = new Array ("site1.com", "site2.com", "site3.com" ...);
// Sites array contains 100 values

var imgs = document.getElementsByTagName( "img" );
for ( var i = 0; i < imgs.length; i++ ) {
    var img = imgs[ i ].src;
    var result = sites._filter( function( site ) {
        return img.match( site )
    });

    // result is an array of matching sites

}
于 2012-04-30T15:10:04.767 回答
1

您的“站点”变量应该是正则表达式而不是数组:

 var sites = /\b(site1\.com|site2\.com|etc|etc)\b/

之后:

 if (img.match(sites))
    ......

如果出于某种原因您更喜欢将“站点”保留在数组中,您还可以“即时”创建一个正则表达式:

var sites = ["site1.com", "site2.com", "site3.com"]
var sitesRegexp = new RegExp("\\b(" + sites.join("|").replace(".", "\\.") + ")\\b")

 ....

 if (img.match(sitesRegexp)
    ......
于 2012-04-30T15:14:00.310 回答
0

您可以扩展 Array 原型,因此它支持所有浏览器...

尝试这个 :

Array.prototype.myContains = function(obj) {
    var i = this.length;
    while (i--) {if (this[i] .indexOf(obj)>-1)  return true; }
    return false;
}

用法 :var t=myArr.myContains(3);

于 2012-04-30T15:18:14.303 回答