0

我们正在遍历 JSON 对象以使用预定义的标题项填充表数据。

(来自这个前一个问题的答案的代码)

var stories = {};
for (var i=0; i<QueryResults.Results.length; i++) {
    var result = QueryResults.Results[i],
        name = result.StoryName
    if (!(name in stories))
        stories[name] = {};
    stories[name][result.Name] = result.State;
}

var keys = ['QA Cycle 1', 'QA Cycle 2', 'Development - GUI', 'Development - Backend'];

var data = "<table><tr><th>Story Name</th><th colspan='2'>Quality Assuance</th><th colspan='2'>Development</th></tr><tr><td>&nbsp;</td>";
for (var i=0; i<keys.length; i++)
    data += "<th>"+keys[i]+"</th>";
data += "</tr>";
for (var storyname in stories) {
    data += "<tr><th>"+storyname+"</th>";
    for (var i=0; i<keys.length; i++)
        data += "<td>"+(stories[storyname][keys[i]] || "n.a.")+"</td>";
    data += "</tr>";
}
data += "</table>";

$('body').append(data);

截至目前,每项任务都有“已定义”、“进行中”、“完成”和“不适用”等状态。

现在,我想将两个子任务“开发 - GUI”和“开发 - 后端”合并到一个主要任务“开发”中,然后通过计算以下规则插入累积状态:

  • 在开发任务下,如果第一个子任务的状态为“已完成”,第二个子任务的状态为“已定义”,则结果将为“进行中”。
  • 如果任何子任务的状态为“NA”并且累积结果将变为“NA”

通过这样做,第二行[即子任务]将从表中删除,累积结果将为主要任务列呈现。

JSFiddle:http: //jsfiddle.net/yokesh/a5HRu/4/

任何建议或帮助都会很棒。提前致谢。

4

1 回答 1

1

简单地改变这个:

var keys = ['QA Cycle 1', 'QA Cycle 2', 'Development'];

…
for (var storyname in stories) {
    var story = stories[storyname];

    // variables for shortening the code
    var sub1 = story['Development - GUI'],
        sub2 = story['Development - Backend'],
        main = 'Development';

    if (sub1 && sub2) { // neither is NA
        if (sub1 == sub2)
            story[main] = sub1;
        else if (sub1=="Completed" && sub2=="Defined")
            story[main] = "In-Progress";
        else
            story[main] = "unknown subtask state combination";
    }
    data += "<tr><th>"+storyname+"</th>";
    for (var i=0; i<keys.length; i++)
        data += "<td>"+(story[keys[i]] || "n.a.")+"</td>";
    data += "</tr>";
}
…
于 2013-08-02T14:25:31.957 回答