JavaScript Q&A Logo
JavaScript Q&A Part of the Q&A Network
Real Questions. Clear Answers.
Ask any question about JavaScript here... and get an instant response.
Q&A Balloon Q&A Logo
Post this Question & Answer:

How do I mock a DOM element in Jest for testing event listeners?

Asked on Jan 06, 2026

Answer

To mock a DOM element in Jest for testing event listeners, you can use Jest's built-in functions to simulate the DOM environment and attach event listeners to mock elements.
<!-- BEGIN COPY / PASTE -->
        // Import necessary functions from Jest
        const { JSDOM } = require('jsdom');

        // Create a mock DOM environment
        const dom = new JSDOM('<!DOCTYPE html><html><body><button id="myButton">Click me</button></body></html>');
        const document = dom.window.document;

        // Select the button element
        const button = document.getElementById('myButton');

        // Mock a click event listener
        const handleClick = jest.fn();
        button.addEventListener('click', handleClick);

        // Simulate a click event
        button.click();

        // Test if the event listener was called
        expect(handleClick).toHaveBeenCalled();
        <!-- END COPY / PASTE -->
Additional Comment:
  • The code uses JSDOM to create a mock DOM environment for testing.
  • A button element is selected using "getElementById".
  • An event listener is added to the button, and "jest.fn()" is used to mock the function.
  • The "click" method simulates a click event on the button.
  • "expect(handleClick).toHaveBeenCalled()" checks if the event listener was triggered.
✅ Answered with JavaScript best practices.
← Back to All Questions

Q&A Network
5,000+ Real Questions. Clear Answers.
JavaScript
Ask Questions / Get Answers about JavaScript!
Security
Ask Questions / Get Answers about Website Security!
CSS
Ask Questions / Get Answers about CSS!
Animation
Ask Questions / Get Answers about Animation!
HTML
Ask Questions / Get Answers about HTML!
Bootstrap
Ask Questions / Get Answers about Bootstrap!
MobileDev
Ask Questions / Get Answers about Mobile Developement!
AI Ethics
Ask Questions / Get Answers about AI Ethics!
AI Marketing
Ask Questions / Get Answers about AI Marketing!
Cloud Computing
Ask Questions / Get Answers about Cloud Computing!
Data Science
Ask Questions / Get Answers about Data Science!
Chatbots
Ask Questions / Get Answers about Chatbots!
Illustration
Ask Questions / Get Answers about Illustration!
Podcasting
Ask Questions / Get Answers about Podcasting!
Sound Design
Ask Questions / Get Answers about Sound Design!
AI Coding
Ask Questions / Get Answers about AI Coding!
3D Design
Ask Questions / Get Answers about 3D Design!
UI/UX Design
Ask Questions / Get Answers about UI/UX Design!
Robotics
Ask Questions / Get Answers about Robotics!
AI
Ask Questions / Get Answers about AI!
Tailwind
Ask Questions / Get Answers about Tailwind!
IoT
Ask Questions / Get Answers about IoT!
DevOps
Ask Questions / Get Answers about DevOps!
AI Video
Ask Questions / Get Answers about AI Video!
Analytics
Ask Questions / Get Answers about Analytics!
Web Development
Ask Questions / Get Answers about Web Development!
WordPress
Ask Questions / Get Answers about WordPress!
AI Business
Ask Questions / Get Answers about AI Business!
Film Production
Ask Questions / Get Answers about Film Production!
Performance
Ask Questions / Get Answers about Web Vitals!
Graphic Design
Ask Questions / Get Answers about Graphic Design!
Web Languages
Ask Questions / Get Answers about Web Languages!
AI Audio
Ask Questions / Get Answers about AI Audio!
Motion Graphics
Ask Questions / Get Answers about Motion Graphics!
Monetization
Ask Questions / Get Answers about Ad & Monetization!
Web Hosting
Ask Questions / Get Answers about Hosting!
SEO
Ask Questions / Get Answers about SEO!
Cybersecurity
Ask Questions / Get Answers about Cybersecurity!
AI Education
Ask Questions / Get Answers about AI Education!
VR & AR
Ask Questions / Get Answers about VR & AR!
Photography
Ask Questions / Get Answers about Photography!
AI Design
Ask Questions / Get Answers about AI Design!
Networking
Ask Questions / Get Answers about Networking!
Quantum
Ask Questions / Get Answers about Quantum Computing!
AI Writing
Ask Questions / Get Answers about AI Writing!
Video Editing
Ask Questions / Get Answers about Video Editing!
Creative Writing
Ask Questions / Get Answers about Creative Writing!
AI Images
Ask Questions / Get Answers about AI Images!