не верно работает onclick. Подскажите плиз
var tower1 = document.getElementById('tower1'); tower1.onclick = build('tower1'); function build(tower) { document.getElementById(tower).disabled = 'true'; } Доброго времени суток! Подскажите, почему у меня данный код выполняется сразу, как загрузилась страница? Т.е. кнопка "tower1" уже сразу неактивна. Хочу сделать чтобы при клике на не, она стала неактивной. В чем ошибаюсь? И почему нельзя сделать функцию, которая бы запускалась при нажатии кнопки? |
tower1.onclick = build('tower1'); /* тут вызов функции и присвоение результата свойству onclick */ tower1.onclick = build; /* тут просто присвоение свойству функции */ |
mrdeath4,
http://learn.javascript.ru/bind |
я извиняюсь, че-то я не понял, как решить проблему то? )
Все, до меня дошло. Правда не сразу. Спасибо большое всем. |
<html> <head> <title>example</title> </head> <body> <input type="button" id="tower1" value="click me"> <script> var tower1 = document.getElementById('tower1'); tower1.onclick = build('tower1'); function build(tower) { return function () { document.getElementById(tower).disabled = 'true'; } } </script> </body> </html> |
Спасибо) интересно решение)
|
mrdeath4,
tower1.onclick = build.bind(null,'tower1'); |
Спасибо, а вариант, вызвать в онклике автономную функцию, а в ней, в свою очередь, вызвать свою, сильно хуже?
|
рони, а куда делись все программисты? я см, ты тут один за всех отдуваешься))
|
мой код будет работать в старых ие, у рони в новых браузерах, но на старые браузеры нормальные люди уже забили. его метод более современный))
|
Часовой пояс GMT +3, время: 08:00. |