javascript - SCRIPT5007 IE9 getElementsByTagName

标签 javascript internet-explorer-9

为什么这个简单的事情在 IE 9 中不起作用?它在 FF 和 Chrome 上运行得很好。

<script language="javascript" type="text/javascript">
    function displayBusinessCardData() {
        var xmldata = document.getElementById("xmldata1");
        var bizCard = xmldata.getElementsByTagName("BusinessCard")[0];

        var name = "Name: " +  bizCard.getElementsByTagName("name")[0].firstChild.data;
        var phone1 = "Phone: " +  bizCard.getElementsByTagName("phone")[0].firstChild.data;
        var phone2 = "Phone: " + bizCard.getElementsByTagName("phone")[1].firstChild.data;
        var phone3 = "Phone: " + bizCard.getElementsByTagName("phone")[2].firstChild.data;
        var email = "Email: " + bizCard.getElementsByTagName("email")[0].firstChild.data;

        alert("BusinessCard Data: \n\n" + name + "\n" + phone1 + "\n" + phone2 + "\n" + phone3 + "\n" + email);
    }
</script>

<xml id="xmldata1" style="display:none">
<BusinessCard>
    <name>Joe Marini</Name>
    <phone type="mobile">(415) 555-4567</phone>
    <phone type="work">(800) 555-9876</phone>
    <phone type="fax">(510) 555-1234</phone>
    <email>joe@joe.com</email>
</BusinessCard>
</xml>

<a href="javascript:displayBusinessCardData()">Show Business Card Data</a>
</body>

失败并显示“xmldata.getElementsByTagName("BusinessCard")[0];” bizCard 的结果为空。

最佳答案

我知道这有点晚了,但我遇到了类似的问题,您可能需要考虑将 xml 代码包装在 div 中,然后将其初始化为 xml 文档:

<div id="xmldata">
    <BusinessCard>
        <name>Joe Marini</Name>
        <phone type="mobile">(415) 555-4567</phone>
        <phone type="work">(800) 555-9876</phone>
        <phone type="fax">(510) 555-1234</phone>
        <email>joe@joe.com</email>
    </BusinessCard>
</div>

然后在您的函数中使用 DOMParser 对象创建 xml 文档:

function displayBusinessCardData() {
    var xmlstring= document.getElementById("xmldata").innerHTML;
    parser=new DOMParser();
    var bizCard = parser.parseFromString(xmlstring,"text/xml");

    var name = "Name: " +  bizCard.getElementsByTagName("name")[0].firstChild.data;
    var phone1 = "Phone: " +  bizCard.getElementsByTagName("phone")[0].firstChild.data;
    var phone2 = "Phone: " + bizCard.getElementsByTagName("phone")[1].firstChild.data;
    var phone3 = "Phone: " + bizCard.getElementsByTagName("phone")[2].firstChild.data;
    var email = "Email: " + bizCard.getElementsByTagName("email")[0].firstChild.data;

    alert("BusinessCard Data: \n\n" + name + "\n" + phone1 + "\n" + phone2 + "\n" + phone3 + "\n" + email);
}

希望这有帮助。我要讲的主要内容是,您可以从字符串创建有效的 xml 对象。

最后一件事,在 A 标记中使用 javascript:function() 协议(protocol)是不好的做法

关于javascript - SCRIPT5007 IE9 getElementsByTagName,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6649245/

相关文章:

javascript - 检测毫秒间隔内的秒数

javascript - 第 n 个链接以相同的顺序滚动到第 n 个 li

javascript - 更新 JSON 数组 (Mongoose) 内具体 JSON 对象中的特定字段

javascript - -ms-transform for IE9 在 JavaScript 中

jQuery IE9 JSON.SyntaxError 解析错误,但 JSON 有效

javascript - 如何分别识别select2下拉菜单和select2多选

javascript - 将 onchange 事件添加到 ckeditor 的简单方法?

html - IE9 中的 CSS 相对 href 和 iFrame

internet-explorer - IE9 阻止下载跨域网页字体

html5-video - HTML5 视频错误 - Internet Explorer 9