用于创建嵌套列表的逻辑

时间:2013-03-01 22:34:41

标签: c# html logic nested-lists

我正在使用以下格式的嵌套列表来解释文本文件

- todo
  - clean kitchen
    - do dishes
    - sweep floor
  - cook dinner
    - defrost fish
  - shopping
    - milk
    - eggs

我想将这些项目放入< ul>< / ul>名单。我正在努力弄清楚这样做的逻辑,而目前通过空间数量计算“深度”并添加开始或关闭ul标签是一个可怕的混乱,取决于最后的深度是更高或更低。

要做到这一点,我必须有一个聪明,干净的逻辑,我错过了吗?

1 个答案:

答案 0 :(得分:1)

使用string.IndexOf

应该很容易确定级别
string line = file.ReadLine();
int level = line.IndexOf('-');
level = (level - 1)/2;

处理关卡的逻辑更有趣。像下面这样的东西应该运作良好。

int lastLevel = -1;
string line;
while ((line = file.ReadLine()) != null)
{
    int level = GetLevel(line); // from code above
    int diff = level - lastLevel;
    if (diff > 1)
    {
        // skipping multiple levels forward is probably an error.
        throw new ApplicationException();
    }
    if (diff == 1)
    {
        // next level. Add a <ul>
        WriteUl();
    }
    else if (diff == 0)
    {
        // same level. Add an <li>
        WriteLi(line);
    }
    else
    {
        // need to add </ul>, possibly multiple times
        do
        {
            WriteUlEnd();
            --lastLevel;
        } while (lastLevel > level);
    }
    lastLevel = level;
}

如果你拥有的只是你展示的数据,那真的是唯一的方法。你必须计算空间。