使用XDocument丢失换行符

时间:2011-08-31 21:13:07

标签: c# .net xml linq-to-xml

我正在使用基于XML文档的节点填充TreeView。但是,似乎当我将属性的值放入文本框时,它会丢失它的换行符/回车符/标签。

我首先添加一堆带有“任务名称”的节点。每个任务在XML文档中都有一个或多个查询。像这样:<Tasks><Task name="aTaskName"><Queries><add Query="a long string with tabs and newlines and such" /></Queries></Task> ... </Tasks>

void PopulateQueries(XDocument doc, TreeView tree)
{
    foreach (TreeNode node in tree.Nodes)
    {
        var taskName = node.Text;
        var queriesNode = node.Nodes.Add("Queries");
        var queries = doc.Descendants("Tasks")
            .Descendants("Task")
            .Where(d => d.Attribute("name").Value == taskName)
            .Descendants("Queries")
            .Descendants("add")
            .ToList();

        for (int i = 0; i < queries.Count;i++)
        {
            queriesNode.Nodes.Add(queries[i].Attribute("Query").Value, "query" + i);
        }
    }
}

稍后在节点点击事件中:

void treeView1_NodeMouseClick(object sender, TreeNodeMouseClickEventArgs e)
{
    textBoxRaw.Text = string.Empty;
    if (e.Node.Text.StartsWith("query"))
    {
        textBoxRaw.Text = e.Node.Name;
    }
}

Query属性值包含一个带有换行符,标签符等的长SQL查询。但是,尽管我在Visual Studio中大喊大叫,但似乎没有一个出现在(多行)文本框中。我究竟做错了什么?此外,var doc = XDocument.Load(filename, LoadOptions.PreserveWhitespace);似乎也无效。

1 个答案:

答案 0 :(得分:9)

XML processors must normalize attribute values by converting their whitespace characters (CR, LF, HT, etc) to a single space

如果您想拥有包含此类字符的值,则应考虑将它们作为文本节点而不是属性值。