Front-end/React

[React] 이벤트 핸들링(Event Handling)

늘이 2023. 5. 13. 22:44

 

1. 이벤트 처리

- 컴퓨터 프로그래밍에서 이벤트는 사건이라는 의미를 가짐

 

1) DOM 이벤트 vs 리액트 이벤트

// DOM의 이벤트 처리
<button onclick="activate()">
	Activate
</button>

- 이벤트의 이름(ex. onclick)을 소문자로 표기

- 이벤트를 처리할 함수를 문자열로 전달

 

// 리액트에서 이벤트 처리
<button onClick={activate}>
	Activate
</button>

- 이벤트 이름을 카멜표기법으로 표기

- 이벤트를 처리할 함수 그대로 전달

 

 

2) 이벤트 핸들러(Event Handler)

- 어떤 이벤트가 발생했을 때 해당 이벤트를 처리하는 함수

- 이벤트 리스너(Event Listener)라고도 함(이벤트가 발생하는 것을 계속 듣고 있다는 의미)

- 클래스 컴포넌트: 클래스의 함수로 정의하고 생성자에서 바인딩하여 사용, 클래스 필드 문법도 사용 가능

- 함수 컴포넌트: 함수 안에 함수로 정의하거나 arrow function을 사용해서 정의

 

 

 

2. Arguments 전달

 

1) Argument

- 함수에 전달할 데이터

- 파라미터 또는 매개변수라고 부르기도 함

 

2) 클래스 컴포넌트

- arrow function 사용하기

import React from "react";

// 클래스 필드 문법 사용하여 작성
class ConfirmButton2 extends React.Component {
    constructor(props) {
        super(props);

        // 확인(Confirm)여부를 저장하기 위해 state에 isConfirmed라는 변수를 하나 갖고 있고, 초기값은 false
        this.state = {
            // isConfirmed 라는 Boolean 변수
            isConfirmed: false,
        };
    }

    handleConfirm = () => {
        this.setState((prevState) => ({
            isConfirmed: !prevState.isConfirmed,
        }));
    }

    render() {
        return (
            // 버튼을 클릭하면 handleConfirm() 호출
            <button onClick={this.handleConfirm} disabled={this.state.isConfirmed}>
                {this.state.isConfirmed ? "확인됨" : "확인하기"}
            </button>
        );
    }
}

export default ConfirmButton2;

 

 

- Function.prototype.bind  사용하기

import React from "react";

// 클래스 컴포넌트로 작성
class ConfirmButton1 extends React.Component {
    constructor(props) {
        super(props);

        // 확인(Confirm)여부를 저장하기 위해 state에 isConfirmed라는 변수를 하나 갖고 있고, 초기값은 false
        this.state = {
            // isConfirmed 라는 Boolean 변수
            isConfirmed: false,
        };

         // callback에서 this를 사용하기 위해서 바인딩 필수
        this.handleConfirm = this.handleConfirm.bind(this);
    }

    handleConfirm() {
        this.setState((prevState) => ({
            isConfirmed: !prevState.isConfirmed,
        }));
    }

    render() {
        return (
            // 버튼을 클릭하면 handleConfirm() 호출
            <button onClick={this.handleConfirm} disabled={this.state.isConfirmed}>
                {this.state.isConfirmed ? "확인됨" : "확인하기"}
            </button>
        );
    }
}

export default ConfirmButton1;

 

 

3) 함수 컴포넌트

- 이벤트 핸들러 호출 시 원하는 순서대로 매개변수를 넣어서 사용

import React, {useState} from "react";

// 함수 컴포넌트로 작성
function ConfirmButton3 (props) {
    const[isConfirmed, setIsConfirmed] = useState(false);

    const handleConfirm = () => {
        setIsConfirmed((preIsConfirmed) => !preIsConfirmed);
    };


    return (
        // 버튼을 클릭하면 handleConfirm() 호출
        <button onClick={handleConfirm} disabled={isConfirmed}>
            {isConfirmed ? "확인됨" : "확인하기"}
        </button>
    );

}

export default ConfirmButton3;