I would like to keep my JavaScript and HTML code separate. To do this, I want to make sure that I never use the following syntax:
By assigning an ID to your input element, you will easily (and efficiently) be able to access it with raw javascript
<input type="text" name="text" id="myInput" />
In your separate javascript :
var input = document.getElementById("myInput");
input.onclick = function() {alert("clicked");}
Obviously you would do something more useful than an alert in the onclick function...
To work with JavaScript, first, you have to add an id to the element that you want to append an event. That is because it makes it easy to understand your code and avoids confusion when you are writing your code. So, the HTML line will look like:
<input type="text" name="text" id="myInputType1" />
There must be no more than one id per element that is unique in the whole document. Now, there are three main ways to add events:
/* First */
document.getElementById("myInputType1").onclick = function(){
/*Your code goes here */
};
/* Second */
function Func(){
/*Your code goes here */
}
document.getElementById("myInputType1").onclick = Func;
/* Third */
function Func(){
/*Your code goes here */
}
document.getElementById("myInputType1").addEventListener("click", Func, false);
The advantage of the last one is that you can append as many "click" (or "mouseover", ...) events as you like, and removing them one by one is possible too. But it does not work with IE<9. Instead, you have to use:
document.getElementById("myInputType1").attachEvent("onclick", Func);
jQuery way:
$("#myInputType1").click(function(){
/*Your code goes here */
});
If you give your element and ID, you can do:
var el = document.getElementById("text");
el.addEventListener("click", function(/*put code here*/) {}, false);