javascript - 如何调用对象当前状态对应的函数?
问题描述
该对象是对真实设备的一种抽象。如果按下多个按钮,设备会给出一个特定值。组合很多,大概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");
推荐阅读
- entity-framework-6 - 字段 Pdf 必须是字符串或数组类型,最大长度为 '4000'
- jquery - 如何获取数据表“标题名称”
- elasticsearch - 如何查询包含具有至少一个多边形匹配地理形状过滤器的多边形数组的文档?
- css - 具有固定背景图像 css 的圆形动画
- libgdx - box2d 中的软约束是什么?
- apache-spark - 有没有办法根据 pyspark 中的索引对数据帧进行切片?
- c# - 如何在不单击按钮的情况下直接使用 RadioButtons 和 CheckBoxes 输出到 TexBox
- android - 为什么 IncomingNumber 总是空的?
- javascript - Angular 2 表单验证触碰和脏返回错误,找不到原因
- c# - System.ObservableExtensions.Subscribe:不明确的引用