为什么XmlDocument.GetElementById总是返回null?

时间:2010-09-23 06:03:56

标签: c# xmldocument sgmlreader

我有一些XML(有效的XHTML),如下所示:

<html>
    <head>
        <script type="text/javascript">
            <![CDATA[
                function change_header(){
                    document.getElementById("myHeader").innerHTML="Nice day!";
                }]]>
        </script>
    </head>
    <body>
        <h1 id="myHeader">Hello World!</h1>
        <button onclick="change_header()">Change text</button>
    </body>
</html>

我正在尝试使用#myHeader获取docment.GetElementById("myHeader")节点,但它始终返回null。为什么呢?

猜测它没有将id属性识别为没有DTD的 id属性?如果是这种情况,我怎么能让它使用HTML DTD?

1 个答案:

答案 0 :(得分:5)

这是因为XmlDocument对id的含义一无所知。您需要在XHTML文档中包含DTD。只需将以下内容放在html文件的开头:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

示例:

string html = @"<!DOCTYPE html PUBLIC ""-//W3C//DTD XHTML 1.0 Transitional//EN"" ""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd""><html><body><div id=""foo"">some content</div></body></html>";
XmlDocument document = new XmlDocument();
document.LoadXml(html);
XmlElement div = document.GetElementById("foo");

请注意,这可能会慢一点,因为需要下载DTD。