我正在尝试根据积分系统来计算某人的肠道健康状况。我可以以任何方式编辑数据结构或逻辑。我只是想编写一个函数和数据结构来处理这种能力。
// Bowel health calculator
var points = 0;
If age is from 30 and 34:
points += 1
If age is from 35 and 40:
points += 2
If daily BMs is from 1 and 3:
points -= 1
If daily BMs is from 4 and 6:
points -= 2
return points;
var points_map = {
age:
{
'35-40': 1,
'40-45': 2,
'45-50': 6,
'50-55': 2,
'55-60': 1,
'60-65': 4,
'65-70': 3,
'70-75': 1,
'75-150': 2
},
dbm:
{
'1-3': -1,
'4-6': -2,
'7-9': -3,
'10-150': 5
}
// This plus about 10 more metrics like them (all with the same "Map a plus or minus value to each range" logic)
};
我有一个完整的数据电子表格,我正在尝试编写DRY版本的代码和DRY版本的数据(即,可能不是'30 -34'的字符串等)在没有大量switch
陈述的情况下处理这类事情。
答案 0 :(得分:2)
我认为更好的结构可能会有:
{
[35,1],
[40,2],
[45,6],
...
[150, null]
},
然后对它进行循环:
for (var i =0; i<points_map.age.length-1; i++)
{
if (val >= points_map.age[i][0] && val<points_map.age[i+1][0])
points += points_map.age[i][1];
}
如果需要,可以提高效率,但你明白了。