ReactJS - Acara

Dalam bab ini, kita akan belajar bagaimana menggunakan event.

Contoh Sederhana

Ini adalah contoh sederhana dimana kita hanya akan menggunakan satu komponen. Kami hanya menambahkanonClick acara yang akan memicu updateState berfungsi setelah tombol diklik.

App.jsx

import React from 'react';

class App extends React.Component {
   constructor(props) {
      super(props);
      
      this.state = {
         data: 'Initial data...'
      }
      this.updateState = this.updateState.bind(this);
   };
   updateState() {
      this.setState({data: 'Data updated...'})
   }
   render() {
      return (
         <div>
            <button onClick = {this.updateState}>CLICK</button>
            <h4>{this.state.data}</h4>
         </div>
      );
   }
}
export default App;

main.js

import React from 'react';
import ReactDOM from 'react-dom';
import App from './App.jsx';

ReactDOM.render(<App/>, document.getElementById('app'));

Ini akan menghasilkan hasil sebagai berikut.

Acara Anak

Kapan kita perlu memperbarui state komponen induk dari anaknya, kita dapat membuat sebuah event handler (updateState) di komponen induk dan meneruskannya sebagai prop (updateStateProp) ke komponen anak tempat kita bisa memanggilnya.

App.jsx

import React from 'react';

class App extends React.Component {
   constructor(props) {
      super(props);
      
      this.state = {
         data: 'Initial data...'
      }
      this.updateState = this.updateState.bind(this);
   };
   updateState() {
      this.setState({data: 'Data updated from the child component...'})
   }
   render() {
      return (
         <div>
            <Content myDataProp = {this.state.data} 
               updateStateProp = {this.updateState}></Content>
         </div>
      );
   }
}
class Content extends React.Component {
   render() {
      return (
         <div>
            <button onClick = {this.props.updateStateProp}>CLICK</button>
            <h3>{this.props.myDataProp}</h3>
         </div>
      );
   }
}
export default App;

main.js

import React from 'react';
import ReactDOM from 'react-dom';
import App from './App.jsx';

ReactDOM.render(<App/>, document.getElementById('app'));

Ini akan menghasilkan hasil sebagai berikut.