Links take you to a certain part of the page, another page of the website, or another website entirely. Buttons, on the other hand, are usually manipulated by JavaScript events so they can trigger certain functionality.
In this tutorial, we are going to explore the two different ways of executing click events in JavaScript using two different methods.
First, we'll look at the traditional onclick style that you do right from the HTML page. Then we'll see how the more modern "click" eventListner works, which lets you separate the HTML from the JavaScript.
How to Use the onclick event in JavaScript
The onclick event executes a certain functionality when a button is clicked. This could be when a user submits a form, when you change certain content on the web page, and other things like that.
You place the JavaScript function you want to execute inside the opening tag of the button.
Note that the onclick attribute is purely JavaScript. The value it takes, which is the function you want to execute, says it all, as it is invoked right within the opening tag.
In JavaScript, you invoke a function by calling its name, then you put a parenthesis after the function identifier (the name).
onclick event example
I have prepared some basic HTML with a little bit of styling so we can put the onclick event into real-world practice.
<div>
<p class="name">freeCodeCamp</p>
<button>Change to Blue</button>
</div>
And here's the CSS to make it look good, along with all the rest of the example code:
body{
display: flex;
align-items: center;
justify-content: center;
height: 100vh;
}
p{
font-size: 2rem;
}
button{
padding: 7px;
border: none;
border-radius: 4px;
cursor: pointer;
}
button.blue{
background-color: #3498db;
}
button.green{
background-color: #2ecc71;
}
button.orange{
background-color: orangered;
}
So, on the web page, this is what we have:
Our aim is to change the color of the text to blue when we click the button. So we need to add an onclick attribute to our button, then write the JavaScript function to change the color.
So we need to make a slight change in our HTML:
<div>
<p class="name">freeCodeCamp</p>
<button onclick="changeColor()">Change to Blue</button>
</div>
The function we want to execute is changeColor(). So we need to write it in a JavaScript file, or in the HTML file inside a <script> tag.
If you want to write your script in a JavaScript file, you need to link it in the HTML using the syntax below:
<script src="path-to-javascript-file"></script>
If you want to write the script in an HTML file, just put it inside the script tag:
<script>
// Your Scripts
</script>
Now, let’s write our changeColor() function.
First of all, we need to select the element we want to manipulate, which is the freeCodeCamp text inside the <p> tag.
In JavaScript, you do that with the DOM’s getElementById(), getElementsByClassName(), or the querySelector() methods. Then you store the value in a variable.
In this tutorial, I will be using querySelector() because it is more modern and it's faster. I will also be using const to declare our variables instead of let and var, because with const, things are safer as the variable becomes read-only.
const name = document.querySelector(".name");
Now that we have the text selected, let's write our function. In JavaScript, the basic function syntax looks like this:
functionfuncctionName(){
// What to do
}
So let’s write our function:
functionchangeColor(){
name.style.color ="blue";
}
What’s going on?
Remember from the HTML that changeColor() is the function we are going to execute. That’s why our function identifier (name) is set to changeColor. If the name doesn’t correlate with what’s in the HTML, it won’t work.
In the DOM (Document Object Model, refers to all of the HTML), to change anything that relates to style, you need to write “style” then a dot (.). This is followed by what you want to change, which might be the color, background color, font size, and so on.
So, inside our function, we take the name variable we declared to get our freeCodeCamp text, then we change the color to blue.
The color of our the text turns blue any time the button is clicked:
Our code is working!
We could take things a little bit further by changing our text to be more colors:
So, what we want to do is change the text to blue, green, and orange-red.
This time around, the onclick functions in our HTML take the values of the color we want to change the text to. These are called parameters in JavaScript. The function we'll write takes its own too, which we will call “color”.
Our web page changed a little:
So, let's select our freeCodeCamp text and write the function to change its color to blue, green, and orange-red:
const name = document.querySelector(".name");
functionchangeColor(color){
name.style.color = color;
}
The block of code in the function takes the name variable (where we stored our freeCodeCamp text), then set the color to whatever we passed into the changeColor() functions in the HTML buttons.
How to Use the click eventListener in JavaScript
In JavaScript, there are multiple ways of doing the same thing. As JavaScript itself evolved over time, we started needing to separate the HTML, CSS, and JavaScript code in order to comply with best practices.
Event listeners make this possible as they let you separate the JavaScript from the HTML. You can also do this with onclick, but lets take another approach here.
Now, let's change the freeCodeCampt text to blue by using the click eventListner
This is our new HTML:
<div>
<p class="name">freeCodeCamp</p>
<button>Change Color</button>
</div>
And this is what it looks like:
This time around in our script, we need to select the button too (not just the freeCodeCamp text). That’s because there’s nothing JavaScript in the opening tag of our button, which is cool.
So, our script looks like this:
const name = document.querySelector(".name");
const btn = document.querySelector("button");
btn.addEventListener("click",function(){
name.style.color ="blue";
});
We can also separate our function totally from the eventListener and our functionality will still remain the same:
btn.addEventListener("click", changeColor);
functionchangeColor(){
name.style.color ="blue";
}
How to Build a " Show More" and "Show Less" Button with JavaScrpit
One of the best ways to learn is by making projects, so let's take what we've learned about the onclick and "click" eventListner to do build something.
When you visit a blog, you often see excerpts of articles first. Then you can click on a "read more" button to show the rest. Let's try to do that.
This is the HTML we are dealing with:
<article id="content">
<p>
freeCodeCamp is one of the best platforms to learn how to code.
freeCodeCamp has a detailed curriculum that will take you from zero to
hero in web development, software engineering, machine learning, and
more.
</p>
<p>
freeCodeCamp also has a YouTube channel containing over 1000 videos on
web development, software engineering, machine learning, data science,
freelance web development, database administration, and pretty much
anything related to tech. To get updates when videos are uploaded, you
need to subscribe to the channel and turn on notifications. You can also
follow freeCodeCamp on Twitter, where links to well written articles and
videos are tweeted daily.
</p>
<p>
Since no one has to pay to learn how to code on freeCodeCamp,
freeCodeCamp runs on voluntary donations from donors all around the
world in order to pay employees and maintain servers. If you are
generous enough consider joining the donors.
</p>
</article>
<button onclick="showMore()">Show more</button>
It’s simple HTML with some facts about freeCodeCamp. And there's a button we already attach an onclick to. The function we want to execute is showMore(), which we will write soon.
Without a CSS, this is what we have:
It's not super ugly, but we can make it look better and act the way we want it to. So we have some CSS which I will explain below:
<style>
*{
margin: 0;
padding: 0;
box-sizing: border-box;
}
body{
background: #f1f1f1;
display: flex;
align-items: center;
justify-content: center;
flex-direction: column;
}
article{
width: 400px;
background: #fff;
padding: 20px 20px 0;
font-size: 18px;
Want to print your doc? This is not the way.
Try clicking the ⋯ next to your doc name or using a keyboard shortcut (