Прокрутите цикл формы с помощью javascript?

У меня есть такая форма:

<form name="calc" action="" id="calc">
<?php for($i=0; $i<15; $i++) { ?>
<input type="text" name="txt1[$i]" onkeyup="calcNumber()"/>
<input type="text" name="txt2[$i]" onkeyup="calcNumber()"/>
<input type="text" name="txt3[$i]" onkeyup="calcNumber()"/>

<?php } ?>
</form>

И это код javascript:

<script type="text/javascript">
function calcNumber() {

for(var j=0; j<15; j++) {

var totNumber[j] = document.calc.txt1[j].value + document.calc.txt2[j].value + document.calc.txt3[j].value;

document.getElementById('tot[j]').innerHTML = totNumber[j];
}

}
</script>

Нет ошибок. Но результата тоже нет. Пожалуйста, дайте мне знать, что я сделал неправильно. Благодарю.

1
добавлено
Просмотры: 1
id не является name
добавлено автор mkoryak, источник
Пожалуйста, опубликуйте выходной HTML, а не только PHP ...
добавлено автор Dennis, источник
Пожалуйста, опубликуйте выходной HTML, а не только PHP ...
добавлено автор Dennis, источник
@mkoryak, вы имеете в виду, что я должен написать поля ввода, подобные этому? <input type = "text" name = "txt1 [<? PHP echo $ i;?>]" id = "txt1 [<? PHP echo $ i;?>]" />
добавлено автор Lorek Bryanson, источник
@mkoryak, вы имеете в виду, что я должен написать поля ввода, подобные этому? <input type = "text" name = "txt1 [<? PHP echo $ i;?>]" id = "txt1 [<? PHP echo $ i;?>]" />
добавлено автор Lorek Bryanson, источник
У кого-нибудь есть другие идеи? Я все еще не мог заставить это работать.
добавлено автор Lorek Bryanson, источник
У кого-нибудь есть другие идеи? Я все еще не мог заставить это работать.
добавлено автор Lorek Bryanson, источник

4 ответы

Fix your html to the following.

<input type="text" name="txt1[<?php echo $i;?>]" onkeyup="calcNumber()"/>
<input type="text" name="txt2[<?php echo $i;?>]" onkeyup="calcNumber()"/>
<input type="text" name="txt3[<?php echo $i;?>]" onkeyup="calcNumber()"/>

And the current line of your javascript:

document.getElementById ('tot [' + j + ']'). innerHTML = totNumber;

totNumber isn't an array, and don't need to be in this case.

Проблема

Ваш обработанный html - это именно тот html, который вы указали в своем вопросе, $ i не заменяется номером, потому что он не находится внутри тегов <? Php?> .

0
добавлено
не забудьте исправить свой html и включить атрибут id на входах;)
добавлено автор mkoryak, источник
Спасибо за ваше прямое объяснение. Теперь я понял, что проблема в форме. Но я не знаю, почему я все еще не мог заставить его работать. Поле остается пустым.
добавлено автор Lorek Bryanson, источник

Fix your html to the following.

<input type="text" name="txt1[<?php echo $i;?>]" onkeyup="calcNumber()"/>
<input type="text" name="txt2[<?php echo $i;?>]" onkeyup="calcNumber()"/>
<input type="text" name="txt3[<?php echo $i;?>]" onkeyup="calcNumber()"/>

And the current line of your javascript:

document.getElementById ('tot [' + j + ']'). innerHTML = totNumber;

totNumber isn't an array, and don't need to be in this case.

Проблема

Ваш обработанный html - это именно тот html, который вы указали в своем вопросе, $ i не заменяется номером, потому что он не находится внутри тегов <? Php?> .

0
добавлено
не забудьте исправить свой html и включить атрибут id на входах;)
добавлено автор mkoryak, источник
Спасибо за ваше прямое объяснение. Теперь я понял, что проблема в форме. Но я не знаю, почему я все еще не мог заставить его работать. Поле остается пустым.
добавлено автор Lorek Bryanson, источник

Я выяснил проблему, просто вставьте массив после tot в function calcNumber() , но не внутри tot .

Спасибо, ребята, за вашу помощь.

0
добавлено

Я выяснил проблему, просто вставьте массив после tot в function calcNumber() , но не внутри tot .

Спасибо, ребята, за вашу помощь.

0
добавлено