假设我有这个:
var blockedTile = new Array("118", "67", "190", "43", "135", "520");
有更多的数组元素,但出于可读性目的,这些元素很少。无论如何,我可以做一个“for”循环,但每次点击地图时它都会做 500 次循环……有没有其他方法可以查看某个字符串是否在数组中?
假设我有这个:
var blockedTile = new Array("118", "67", "190", "43", "135", "520");
有更多的数组元素,但出于可读性目的,这些元素很少。无论如何,我可以做一个“for”循环,但每次点击地图时它都会做 500 次循环……有没有其他方法可以查看某个字符串是否在数组中?
试试这个:
if(blockedTile.indexOf("118") != -1)
{
// element found
}
如前所述,如果您的浏览器支持indexOf()
,那就太好了!如果没有,您需要对其进行 pollyfil 或依赖实用工具带,如lodash/underscore。
只是想添加这个较新的ES2016补充(以保持这个问题的更新):
if (blockedTile.includes("118")) {
// found element
}
2019 年最好的方法是使用 .includes()
[1, 2, 3].includes(2); // true
[1, 2, 3].includes(4); // false
[1, 2, 3].includes(1, 2); // false
第一个参数是您要搜索的内容。第二个参数是该数组中开始搜索的索引位置。
如果您需要在这里浏览 - 有很多遗留答案。
function in_array(needle, haystack){
var found = 0;
for (var i=0, len=haystack.length;i<len;i++) {
if (haystack[i] == needle) return i;
found++;
}
return -1;
}
if(in_array("118",array)!= -1){
//is in array
}
一些浏览器支持Array.indexOf()
.
如果没有,你可以Array
通过它的原型来增强对象,就像这样......
if (!Array.prototype.indexOf)
{
Array.prototype.indexOf = function(searchElement /*, fromIndex */)
{
"use strict";
if (this === void 0 || 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 !== (1 / 0) && n !== -(1 / 0))
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;
};
}
来源。