My event handler is executed before the event is fired, why? [duplicate]
Asked Answered
G

2

5

I have a pop up window with a button. When I click the button I want something to happen, say an alert.

The issue I am having is that the onclick event fires as soon as the popup is launched and not when the button is clicked.

Here is the code. Any thoughts will be much appreciated.

var popup = open("", "Popup", "width=300,height=200");
var btn = popup.document.createElement("button");
btn.style.height = "50px";
btn.style.width = "150px";
popup.document.body.appendChild(btn);

btn.innerHTML="button1";
btn.onclick = alert("hello");
Grams answered 27/6, 2013 at 19:41 Comment(0)
A
15

In your code

btn.onclick = alert("hello");

onclick is not fired. Just alert is executed immediately. You should wrap it into a function:

btn.onclick = function(){ alert("hello");}
Ahab answered 27/6, 2013 at 19:42 Comment(1)
May I ask why is the first function being executed ? Looks like we are just assigning a function to the onclick event.Haro
O
1

assign function to the btn.onclick event.

Obnoxious answered 27/6, 2013 at 19:43 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.