๋ณธ๋ฌธ ๋ฐ”๋กœ๊ฐ€๊ธฐ

Develop Study ๐Ÿ’ป

react study / ์ปดํฌ๋„ŒํŠธ์—์„œ ๊ฐ’ ๋ฐ›์•„ ๋ฐ”๊พธ๊ธฐ

728x90

Counter.js

import React from 'react';
import { useState } from 'react';

function Counter() {
    const [number, setNumber] = useState(0);

    const onIncrease = () => {
        setNumber(prevNumber => prevNumber + 1);
    }

    const onDecrease = () => {
        setNumber(prevNumber => prevNumber- 1);
    }

    return (
        <div>
            <h1>{number}</h1>
            <button onClick={onIncrease}>+1</button>
            <button onClick={onDecrease}>-1</button>


        </div>
    )
}

export default Counter;

๋งค์šฐ ์‰ฌ์šด ์˜ˆ์ œ! ํ•œ๋ฒˆ ํ•ด๋ณด์ž

๋ฒ„ํŠผ์„ ๋‹ฌ์•„์ฃผ๊ณ  ๋ˆ„๋ฅด๋Š”๋Œ€๋กœ ์ˆซ์ž ๋ฐ”๊พธ๊ธฐ

onClick ์ด๋ฒˆํŠธ๋ฅผ ๋„ฃ์–ด์ค€๋‹ค

 

on์ด๋ฒคํŠธ์ด๋ฆ„ = {์‹คํ–‰ํ•˜๊ณ ์ž ํ•˜๋Š” ํ•จ์ˆ˜}

ํ•จ์ˆ˜ "์ด๋ฆ„"์„ ๋„ฃ์–ด์ฃผ๋Š”๊ฒƒ์ด๋‹ค

 

useState๋Š” ๋ฆฌ์•กํŠธ ํŒจํ‚ค์ง€์— ์žˆ๋Š” ํ•จ์ˆ˜์ด๋ฉฐ importํ•ด ์‚ฌ์šฉํ•œ๋‹ค

์ด๊ฒƒ์„ ์ด์šฉํ•˜๋ฉด ์ปดํฌ๋„ŒํŠธ์—์„œ ์ƒํƒœ๋ฅผ ๊ด€๋ฆฌํ•  ์ˆ˜ ์žˆ๋‹ค๊ณ  ํ•œ๋‹ค

 

๋ฐฐ์—ด๋กœ ๋ฐ˜ํ™˜๋˜๋Š”๋ฐ ์ฒซ๋ฒˆ์งธ ์›์†Œ(number)๋Š” ํ˜„์žฌ์ƒํƒœ, ๋‘๋ฒˆ์งธ ์›์†Œ๋Š” Setterํ•จ์ˆ˜๋ผ ํ•œ๋‹ค

๊ทธ๋Ÿฌ๋‹ˆ๊นŒ ๋ฐฐ์—ด์ด ์ด๋Ÿฐ ๋Š๋‚Œ...

 

useState(0)

[0] number
[1] setNumber

 

 

 

 

 

728x90