假设我有一个看起来像那个的对象:
var ticket = {
state:"Closed",
opened:"2014-01-12",
assiged:"2014-02-03",
resolved:"2014-04-22",
propose:"",
closed:"2014-05-03"
tmpstateholder:""
};
我想要的是一个在表格中给出字符串参数的函数 2014-02-25
计算该票证在该日期的状态,然后返回该对象。
function calculateState(d,datestring){
//Calculate in what state the object is in depending on the date string
//For example in this case when datestring = 2014-02-25 it should return;
d.tmpstateholder="assiged"
return d;
}
另请注意,如果票证不必转到所有州,例如在上面的示例中,票证尚未进入建议状态。
请注意,故障单对象也可能如下所示。
var ticket = {
state:"Closed",
opened:"2014-01-12",
assiged:"",
resolved:"",
propose:"",
closed:"2014-05-03",
tmpstateholder:""
};
答案 0 :(得分:0)
你可以简单地枚举该对象,过滤掉那些日期在我们寻找的时间之后的状态,并取其余的最大值:
function calculateState(d, datestring) {
var maxdate = "", state = "";
for (var s in d)
if (d[s] <= datestring && d[s] > maxdate) {
maxdate = d[s];
state = s;
}
return state;
}
现在,如果您的对象不仅包含状态,还包含其他属性(不包含日期),则您需要匹配类似日期的属性值:
…
if (/^\d{4}-\d{2}-\d{2}/.test(d[s]) && d[s] <= …
或创建一组所有可能的状态并迭代它而不是对象的属性名称:
…
var allStates = ["opened", "assiged", "resolved", "proposed", "closed"];
for (var i=0; i<allStates.length; i++) {
var s = allStates[i];
…
如果您有很多可能的状态,并且它们只能以一个顺序运行,那么您也可以在该状态列表上使用二进制搜索。