比较一个值和多个选项的最好方法是什么?
我知道有很多方法可以做到这一点,但我在寻找最整洁的方法。
我之所以这样问,是因为我希望这是可行的(当你看着它的时候,显然不是这样的):
if (foobar == (foo||bar) ) {
//do something
}发布于 2012-02-03 07:35:36
不要试图太偷偷摸摸,特别是当它不必要地影响性能的时候。如果你真的有一大堆的比较要做,只需要很好地格式化它。
if (foobar === foo ||
foobar === bar ||
foobar === baz ||
foobar === pew) {
//do something
}发布于 2012-02-03 07:12:56
我用来做的是将这些多个值放入一个数组中,如下所示
var options = [foo, bar];然后,使用indexOf()
if(options.indexOf(foobar) > -1){
//do something
}对于漂亮:
if([foo, bar].indexOf(foobar) +1){
//you can't get any more pretty than this :)
}对于较旧的浏览器:
( 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;
}
}发布于 2012-02-03 07:18:38
由于还没有人添加适用于两个比较的显而易见的解决方案,因此我将提供它:
if (foobar === foo || foobar === bar) {
//do something
}而且,如果你有很多值(可能是数百或数千),那么我建议你做一个集合,因为这使得比较代码非常干净和简单,而且在运行时速度很快:
// pre-construct the Set
var tSet = new Set(["foo", "bar", "test1", "test2", "test3", ...]);
// test the Set at runtime
if (tSet.has(foobar)) {
// do something
}对于ES6之前的版本,您可以获得一组多边形填充,其中有许多。其中一个是在此other answer中描述的。
https://stackoverflow.com/questions/9121395
复制相似问题