为什么在获取nodeValue时null会继续返回,即使它正确显示?

时间:2011-09-02 15:37:38

标签: javascript dom css-selectors nodevalue

这让我疯了。我正在通过Ajax将代码插入页面。插入代码后,我正在运行一个函数来获取其中一个DIV的文本并将其显示在页面上的另一个位置。

有人可以告诉我为什么我一直收到一个JavaScript错误,说明currentText为空,即使文本在页面的其他位置显示正确吗?

var currentText = document.getElementById("current-text"),
updatedTextHere = document.getElementById("updated-text-here");

updatedTextHere.innerHTML = currentText.firstChild.nodeValue;

这是它抓取文本值的代码,它通过Ajax插入到主页面中:

<div id="current-text" class="hide">January 1, 2011</div>

更新:

以下是它的外观:

getDate = function () {
    var currentText = document.getElementById("current-text"),
    updatedTextHere = document.getElementById("updated-text-here");

    updatedTextHere.innerHTML = currentText.firstChild.nodeValue;
},

htmlready = function () {
    myDiv.innerHTML = xmlRequest.responseText;
    getDate();
},

1 个答案:

答案 0 :(得分:3)

您遇到的问题是firstChild不是currentText的节点。您的nodeValue没有值,因为它不存在。您应该使用innerHTMLtextContent代替。

更改为...

updatedTextHere.innerHTML = currentText.firstChild.textContent; // or innerHTML