JavaScript Traverse Table Issue - PullRequest
       14

JavaScript Traverse Table Issue

1 голос
/ 26 февраля 2010

Почему этот скрипт выдает (IE) или вставляет (FF) в первую ячейку таблицы, содержащую текст, который он находит?

<!html>
<head>
<script type="text/javascript">
function CheckChildren(obj)
{
        alert(obj.id + ' ' + obj.tagName + ' ' + obj.childNodes.length);
        for ( i = 0; i < obj.childNodes.length; i++)
        {
                CheckChildren(obj.childNodes[i]);
        }
        alert(obj.id);
        return false;
}
</script>
</head>
<body>

<table id="table">
<tr id="a"><td id="b">b</td><td id="c">c</td></tr>
<tr id="d"><td id="e">e</td><td id="f">f</td></tr>
</table>
<input type="button" onclick="CheckChildren(document.getElementById('table'))" value="click">
</body>
</html>

1 Ответ

3 голосов
/ 26 февраля 2010

Попробуйте поставить слово "var" перед "i" в цикле for.

  for ( var i = 0; i < obj.childNodes.length; i++)

Без этого ваш код ссылается на глобальную переменную "i", поэтому каждая рекурсивная итерация возвращает его в ноль.

...