An event is an action that could be triggered as a result of the user action or system generated event. For example, a mouse click, loading of a web page, pressing a key, window resizes, and other interactions are called events.
React has its own event handling system which is very similar to handling events on DOM elements. The react event handling system is known as Synthetic Events. The synthetic event is a cross-browser wrapper of the browser's native event.
Handling events with react have some syntactic differences from handling events on DOM. These are:
Event declaration in plain HTML:
Event declaration in React:
3. In react, we cannot return false to prevent the default behavior. We must call preventDefault event explicitly to prevent the default behavior. For example:
In plain HTML, to prevent the default link behavior of opening a new page, we can write:
Click_Me
In React, we can write it as:
function ActionLink() { function handleClick(e) { e.preventDefault(); console.log('You had clicked a Link.'); } return ( Click_Me ); }
In the above example, e is a Synthetic Event which defines according to the W3C spec.
Now let us see how to use Event in React.
In the below example, we have used only one component and adding an onChange event. This event will trigger the changeText function, which returns the company name.
import React, { Component } from 'react'; class App extends React.Component { constructor(props) { super(props); this.state = { companyName: '' }; } changeText(event) { this.setState({ companyName: event.target.value }); } render() { return (); } } export default App;Simple Event Example
You entered: { this.state.companyName }
Output
When you execute the above code, you will get the following output.
After entering the name in the textbox, you will get the output as like below screen.