ZetCode

JavaScript element.click()

last modified April 2, 2025

In this article, we explore the element.click() method in JavaScript. This method allows developers to programmatically simulate mouse clicks on DOM elements, triggering their click events.

Basic Definition

The element.click() method simulates a mouse click on an element. It triggers the element's click event as if the user had clicked it manually.

This method is useful for automating user interactions, testing, and creating more dynamic user experiences. It works on any element that can receive click events, including buttons, links, and form elements.

Basic click() Example

This example demonstrates how to programmatically click a button using the click() method.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Basic click() Example</title>
</head>
<body>

<button id="myButton" onclick="alert('Button clicked!')">Click Me</button>
<button onclick="simulateClick()">Simulate Click</button>

<script>
    function simulateClick() {
        const button = document.getElementById('myButton');
        button.click();
    }
</script>

</body>
</html>

In this example, we have two buttons. The first button shows an alert when clicked. The second button's click handler calls simulateClick().

The simulateClick() function gets the first button using getElementById and calls its click() method. This triggers the same behavior as a manual click.

Triggering Form Submission

This example shows how to use click() to submit a form programmatically.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Form Submission</title>
</head>
<body>

<form id="myForm" onsubmit="alert('Form submitted!'); return false">
    <input type="text" placeholder="Enter your name">
    <button type="submit" id="submitBtn">Submit</button>
</form>
<button onclick="submitForm()">Auto Submit</button>

<script>
    function submitForm() {
        const submitBtn = document.getElementById('submitBtn');
        submitBtn.click();
    }
</script>

</body>
</html>

Here we have a form with a submit button and a separate "Auto Submit" button. When the "Auto Submit" button is clicked, it programmatically clicks the form's submit button.

This demonstrates how click() can be used to trigger form submission without direct user interaction. The form's submit event handler still executes as expected.

Simulating Link Clicks

This example demonstrates using click() to simulate clicking on a link element.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Link Click Simulation</title>
</head>
<body>

<a id="myLink" href="https://example.com" target="_blank">Visit Example.com</a>
<button onclick="clickLink()">Click Link Programmatically</button>

<script>
    function clickLink() {
        const link = document.getElementById('myLink');
        link.click();
    }
</script>

</body>
</html>

In this example, we have a hyperlink and a button. The button's click handler programmatically clicks the link using the click() method.

This will open the link in a new tab (due to the target="_blank" attribute), just as if the user had clicked it manually. This technique can be useful for creating custom navigation controls.

Checkbox Toggling

This example shows how to use click() to toggle checkbox states.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Checkbox Toggling</title>
</head>
<body>

<input type="checkbox" id="myCheckbox"> Accept Terms
<button onclick="toggleCheckbox()">Toggle Checkbox</button>
<p id="status">Checkbox is unchecked</p>

<script>
    const checkbox = document.getElementById('myCheckbox');
    const statusText = document.getElementById('status');
    
    checkbox.addEventListener('change', function() {
        statusText.textContent = `Checkbox is ${this.checked ? 'checked' : 'unchecked'}`;
    });
    
    function toggleCheckbox() {
        checkbox.click();
    }
</script>

</body>
</html>

Here we have a checkbox, a toggle button, and a status paragraph. The checkbox has a change event listener that updates the status text.

The toggleCheckbox() function uses click() to programmatically toggle the checkbox state. This triggers the change event just like a manual click would.

Custom File Input Trigger

This example demonstrates a common use case for click(): triggering a hidden file input from a custom button.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>File Input Trigger</title>
</head>
<body>

<input type="file" id="fileInput" style="display: none">
<button onclick="triggerFileInput()">Upload File</button>
<p id="fileName">No file selected</p>

<script>
    const fileInput = document.getElementById('fileInput');
    const fileName = document.getElementById('fileName');
    
    fileInput.addEventListener('change', function() {
        if (this.files.length > 0) {
            fileName.textContent = `Selected: ${this.files[0].name}`;
        }
    });
    
    function triggerFileInput() {
        fileInput.click();
    }
</script>

</body>
</html>

In this example, we have a hidden file input element and a visible button. Clicking the button triggers the file input's click handler programmatically.

This is a common pattern for customizing file upload interfaces while maintaining the native file selection dialog. The change event still fires when a file is selected.

Source

MDN click() Documentation

In this article, we have shown how to use the element.click() method in JavaScript. This powerful method allows for programmatic simulation of user interactions with various DOM elements.

Author

My name is Jan Bodnar, and I am a passionate programmer with extensive programming experience. I have been writing programming articles since 2007. To date, I have authored over 1,400 articles and 8 e-books. I possess more than ten years of experience in teaching programming.

List all JS DOM tutorials.