这个对象是对真实设备的一种抽象。 如果按下多个按钮,设备会给出一个特定值。组合很多,大概有70种。 在这种情况下如何最好地组织代码?起初我想使用 switch 构造,但是当我计算组合的数量时,我觉得这是个坏主意。
const device = {
mode: false,
zero: false,
minus10: false,
minus20: false,
minus30: false,
minus40: false,
speed: false
};
switch(device.zero.toString() + device.minus10 + device.minus20 + device.minus30 + device.minus40 + device.mode) {
case "falsefalsefalsefalsefalsefalse":
indicator.animate({path:"M 265 665 L 160 566"}, 1000, "easeInOut");
break;
case "truefalsefalsefalsefalsefalse":
indicator.animate({path:"M 265 665 L 160 566"}, 1000, "easeInOut");
break;
case "falsetruefalsefalsefalsefalse":
indicator.animate({path:"M 265 665 L 161 564"}, 1000, "easeInOut");
break;
case "falsefalsetruefalsefalsefalse":
indicator.animate({path:"M 265 665 L 162 563"}, 1000, "easeInOut");
break;
case "falsefalsefalsetruefalsefalse":
indicator.animate({path:"M 265 665 L 163 562"}, 1000, "easeInOut");
break;
case "falsefalsefalsefalsetruefalse":
indicator.animate({path:"M 265 665 L 164 561"}, 1000, "easeInOut");
break;
...
}
最佳答案
将true/false
值视为1/0
,并将它们用作多维数组的索引:
const paths =
[[[[[[["M 265 665 L 160 566", "M 265 665 L 160 566"],
["M 265 665 L 161 564", "M 265 665 L 162 563"]]
[["M 265 665 L 163 562", "M 265 665 L 164 561"],
...;
var cur_path = paths[Number(device.zero)][Number(device.minus10)][Number(device.minus20)]...;
indicator.animate({path: cur_path}, 1000, "easeInOut");
关于javascript - 如何调用对象当前状态对应的函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56263017/