То, как вы это делаете, прекрасно, но ваш прослушиватель событий для события click
должен выглядеть следующим образом:
button.addEventListener("click", function() { alert("alert");});
Обратите внимание, к событию click
следует присоединить "click"
, а не "onclick"
.
Вы также можете попробовать сделать это по-старому:
function onload() {
var button = document.getElementById("buttonid");
// add onclick event
button.onclick = function() {
alert("alert");
}
}
Обновление 1
Вам также необходимо отслеживать IE <9, потому чтоэти против использования <code>attachEvent().Присоедините событие так, чтобы оно работало с браузерами динозавров:
if(button.addEventListener){
button.addEventListener('click', function() { alert("alert");});
} else if(button.attachEvent){ // IE < 9 :(
button.attachEvent('onclick', function() { alert("alert");});
}
Обновление 2
В зависимости от ваших правок должно работать работает простоштраф .
<html>
<head>
<script type="text/javascript">
function init() {
var button = document.getElementById("buttonid");
if(button.addEventListener){
button.addEventListener("click", function() { alert("alert");}, false);
} else if(button.attachEvent){
button.attachEvent("onclick", function() { alert("alert");});
}
};
if(window.addEventListener){
window.addEventListener("load", init, false);
} else if(window.attachEvent){
window.attachEvent("onload", init);
} else{
document.addEventListener("load", init, false);
}
</script>
</head>
<body>
<input type="button" id="buttonid" value="click">
</body>
</html>
Пожалуйста, не используйте window.onload = on_load();
, это предотвратит срабатывание всех других прослушивателей onload
или вы рискуете перезаписать прослушиватель событий.Подумайте о том, чтобы прикрепить событие onload
так, как я предлагаю выше.