Bolt ui

Event Handlers Not Firing - onClick, onChange Not Working

You add onClick, onChange, or other event handlers to elements but they never fire. The function is defined but not being called when the event occurs.

Sometimes works in one component but not another. No console errors.

Error Messages You Might See

onClick fires immediately on render Event handler undefined Clickable element not responding to clicks handleClick is not a function
onClick fires immediately on renderEvent handler undefinedClickable element not responding to clickshandleClick is not a function

Common Causes

  1. Calling function instead of passing reference: onClick={handleClick()} instead of onClick={handleClick}
  2. Event handler called with wrong context (this binding issue)
  3. Event delegation not working - handler on parent not capturing child events
  4. Element disabled or has pointer-events: none
  5. Event handler overridden or removed after mount

How to Fix It

Pass function reference, not invocation: onClick={handleClick} not onClick={handleClick()}

To pass arguments: onClick={() => handleClick(id)} or onClick={e => handleClick(e, id)}

For disabled state: use disabled prop, not conditional rendering

Check element in DevTools - is it actually in the DOM and visible?

Use React DevTools Profiler to see if component is re-rendering on click

Real developers can help you.

Jared Hasson Jared Hasson Full time lead founding dev at a cyber security saas startup, with 10 yoe and a bachelor's in CS. Building & debugging software products is what I've spent my time on for forever rayush33 rayush33 JavaScript (React.js, React Native, Node.js) Developer with demonstrated industry experience of 4+ years, actively looking for opportunities to hone my skills as well as help small-scale business owners with solutions to technical problems Luca Liberati Luca Liberati I work on monoliths and microservices, backends and frontends, manage K8s clusters and love to design apps architecture Meïr Ankri Meïr Ankri Full-stack developer specializing in React / Next.js / Node.js with 6+ years of experience. I've worked across various sectors including automotive (Reezocar/Société Générale), healthcare (Medical Link SaaS), and e-commerce (Glasman). I build web apps end-to-end, from architecture to production, with a focus on scalability, performance, and code quality. I also mentor junior developers and contribute to technical decisions and code reviews. Matthew Jordan Matthew Jordan I've been working at a large software company named Kainos for 2 years, and mainly specialise in Platform Engineering. I regularly enjoy working on software products outside of work, and I'm a huge fan of game development using Unity. I personally enjoy Python & C# in my spare time, but I also specialise in multiple different platform-related technologies from my day job. Anthony Akpan Anthony Akpan Developer with 8 years of experience building softwares fro startups Stanislav Prigodich Stanislav Prigodich 15+ years building iOS and web apps at startups and enterprise companies. I want to use that experience to help builders ship real products - when something breaks, I'm here to fix it. Mehdi Ben Haddou Mehdi Ben Haddou - Founder of Chessigma (1M+ users) & many small projects - ex Founding Engineer @Uplane (YC F25) - ex Software Engineer @Amazon and @Booking.com Costea Adrian Costea Adrian Embedded Engineer specilizing in perception systems. Latest project was a adas camera calibration system. Yovel Cohen Yovel Cohen I got a lot of experience in building Long-horizon AI Agents in production, Backend apps that scale to millions of users and frontend knowledge as well.

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help

Frequently Asked Questions

What's the difference between onClick={fn} and onClick={fn()}?

fn is a reference, fires when clicked. fn() calls immediately on render. Use fn() => fn(args) to pass arguments

Why does my event fire immediately?

You're calling the function onClick={fn()} instead of passing reference onClick={fn}

How do I pass arguments to event handlers?

Use arrow function: onClick={() => handleClick(id, name)}

Related Bolt Issues

Can't fix it yourself?
Real developers can help.

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help