2

这是我正在创建一个 JSON 对象集合的循环:

var sb = new StringBuilder();
var list = DataAccess.Read.EventsByID(id);
foreach (var spevent in list)
{
    sb.AppendFormat("'{0}':'<a href=\"{1}\">{2}</a>',",spevent.StartTimeDt.ToString("MM-dd-yyyy"), spevent.Link, spevent.Title);
}

缺陷是,如果我有多个相同日期的事件,我只会得到最后一个,因为

window.eventscollection = {
    '07-23-2013' : '<a href="#">Item One</a>',
    '07-23-2013' : '<a href="#">Item Two</a>',
}

有两个具有相同对象名称的项目,并且不会重复。

正确的输出是将具有相同日期的所有项目合并为一项,如下所示:

window.eventscollection = {
    '07-23-2013' : '<a href="#">Item One</a><a href="#">Item Two</a>',
}

似乎我需要某种 while 或递归循环来查看下一项是否与当前项具有相同的日期并更改输出,但我似乎无法正确处理。

想法?

4

2 回答 2

3

您可以将同一日期的项目分组为

var sb = new StringBuilder();
var items = DataAccess.Read.EventsByID(id).GroupBy(p=>StartTimeDt.ToString("MM-dd-yyyy"));

然后遍历分组:

foreach (var item in items)
{
    StringBuilder sb2 = new StringBuilder();
    foreach(var subitem in item)
        sb2.Append(String.Format("<a href=\"{1}\">{2}</a>",subitem.Link,subitem.Title));
    sb.AppendFormat("'{0}':'{1}',",item.Key, sb2.ToString());
}
于 2013-07-26T08:43:02.060 回答
1

你首先需要GroupBy在你的清单上:

var sb = new StringBuilder();
var list = DataAccess.Read.EventsByID(id).GroupBy(e => e.StartTimeDt.Date);

然后你可以在循环内循环

foreach (var dt in list)
{
    sb.AppendFormat("'{0}'",dt.Key.ToString("yyyy-MM-dd"))
    foreach (var spevent in dt)
    {
        sb.AppendFormat("'<a href=\"{0}\">{1}</a>',",, spevent.Link, spevent.Title);
    }
}
于 2013-07-26T08:44:02.427 回答