[React] Checkbox (2) — ๋ฒํผ์ผ๋ก ์ ํ ํด์ ํ๊ธฐ
[React] Checkbox (1) — Context API๋ก ์ํ ๊ด๋ฆฌํ๊ธฐ์ ์ด์ด์ง๋ ํฌ์คํ ์ ๋๋ค.
๋ฒํผ์ผ๋ก ์ฒดํฌ๋ฐ์ค ํด์ ํ๊ธฐ
์ฒดํฌ๋ฐ์ค์ ์ํ ๊ด๋ฆฌ๋ฅผ ํ ์ ์๋ค๋ฉด ๋ฒํผ์ผ๋ก ์ฒดํฌ๋ฐ์ค ํด์ ํ๋ ๋ฐฉ๋ฒ์ฏค์ ๊ป์ ๋๋ค.
์ฐ์ ์ฒดํฌ๋ ์์๋ค์ ๋ฒํผ์ผ๋ก ์ถ๋ ฅํด ๋ณด๊ฒ ์ต๋๋ค.
๋ฒํผ ์์ ํ๋๋ Selected.jsx๋ก ๋ง๋ค๊ณ , ์ถ๋ ฅ์ CheckboxList์์ ๊ฐ์ด ํด ๋ณด๊ฒ ์ต๋๋ค.
1. ์ฒดํฌ๋ ์์ ๋ฒํผ์ผ๋ก ์ถ๋ ฅํ๊ธฐ
<div>
{Object.keys(cateObject).map((key, index) => {
return (
<div key={index}>
<Selected value={key} checked={cateObject[key]} />
</div>
);
})}
</div>
CheckboxList.jsx์ return ๋ฌธ์ ์ด๋ฐ ์ฝ๋๋ฅผ ์ถ๊ฐํด ์ค๋๋ค.
value์๋ ํ ์คํธ๋ฅผ ์ ๋ฌํด ์ฃผ๊ณ , checked์๋ true/false ์์ฑ์ ์ ๋ฌํด ์ค๋๋ค.
๊ทธ๋ฆฌ๊ณ ๋ชจ๋ ์์ฑ์ด false๋ผ๋ฉด ์นดํ
๊ณ ๋ฆฌ๋ฅผ ์ ํํด ์ฃผ์ธ์๋ผ๋ ๋ฌธ๊ตฌ๊ฐ ๋จ๋๋ก isAllFalse
๋ผ๋ ๋ณ์๋ ๋ง๋ค์ด ๊ด๋ฆฌํด ์ฃผ๊ฒ ์ต๋๋ค.
const [isAllFalse, setIsAllFalse] = useState(true);
const handleIsAllFalse = () => {
for (const [cate, bool] of Object.entries(cateObject)) {
if (bool === true) {
setIsAllFalse(false);
break;
}
setIsAllFalse(true);
}
}
useEffect(() => {
handleIsAllFalse();
}, [cateObject]);
useState๋ก isAllFalse, setIsAllFalse
๋ฅผ ๋ง๋ค์ด ์ฃผ๊ณ , ์ด๊ธฐ์๋ ์ ํ๋ ๊ฐ์ด ์์ด ์ ๋ถ false์ผ ํ
๋ ์ด๊น๊ฐ์ true๋ก ๋ฃ์ด ์ค๋๋ค.
handleIsAllFalse
๋ cateObject๋ฅผ for๋ฌธ์ผ๋ก ๋๋ฉฐ bool์ด true์ธ ๊ฐ์ด ์๋ค๋ฉด isAllFalse
๋ฅผ false
๋ก ์ค์ ํ๊ณ if ๋ฌธ์ break๋ก ๋ฉ์ถฅ๋๋ค.
๊ทธ๋ ์ง ์๊ณ ์ ๋ถ false๋ผ๋ฉด isAllFalse
๋ฅผ true
๋ก ์ค์ ํด ์ค๋๋ค.
useEffect์ handelIsaFalse
ํจ์๋ฅผ ๋ฃ์ด ์ฃผ๊ณ , cateObject
๊ฐ ๋ฐ๋ ๋๋ง๋ค ์คํ๋๋๋ก ์์กด์ฑ ๋ฐฐ์ด์ ๋ฃ์ด ์ค๋๋ค.
{isAllFalse && (
<div>
<p>์นดํ
๊ณ ๋ฆฌ๋ฅผ ์ง์ ํด ์ฃผ์ธ์.</p>
</div>
)}
๊ทธ๋ฆฌ๊ณ isAllFalse
๊ฐ true
๋ผ๋ฉด ์นดํ
๊ณ ๋ฆฌ๋ฅผ ์ง์ ํด ์ฃผ์ธ์ ๋ฌธ๊ตฌ๋ฅผ ์ถ๋ ฅํด ์ฃผ๋๋ก ํฉ๋๋ค.
์ ์ฒด ์ฝ๋๋ ๋ค์๊ณผ ๊ฐ์ต๋๋ค.
// CheckboxList.jsx
import React, { useContext, useEffect, useState } from "react";
import { CategoryContext } from "store/category";
import Checkbox from "./Checkbox";
import Selected from "./Selected";
const CheckboxList = () => {
const { cateObject } = useContext(CategoryContext);
const [isAllFalse, setIsAllFalse] = useState(true);
const handleIsAllFalse = () => {
for (const [cate, bool] of Object.entries(cateObject)) {
if (bool === true) {
setIsAllFalse(false);
break;
}
setIsAllFalse(true);
}
}
useEffect(() => {
handleIsAllFalse();
}, [cateObject]);
return (
<div>
<div>
{Object.keys(cateObject).map((key) => {
return (
<div className={styles.innerContainer} key={key}>
<Checkbox value={key} checked={cateObject[key]} />
{key}
</div>
);
})}
</div>
<div>
{Object.keys(cateObject).map((key) => {
return (
<div className={styles.innerContainer} key={key}>
<Selected value={key} checked={cateObject[key]} />
</div>
);
})}
{isAllFalse && (
<div>
<p>์นดํ
๊ณ ๋ฆฌ๋ฅผ ์ง์ ํด ์ฃผ์ธ์.</p>
</div>
)}
</div>
</div>
);
};
export default CheckboxList;
2. ๋ฒํผ ์ปดํฌ๋ํธ ๋ง๋ค๊ธฐ
๋ค์์ ๋ฒํผ์ ์ถ๋ ฅํ๋ Selected ์ปดํฌ๋ํธ๋ฅผ ๋ง๋ค ์ฐจ๋ก์ ๋๋ค.
// Selected.jsx
import { CategoryContext } from "store/category";
const Selected = ({ value, checked }) => {
const { cateObject, setCateObject } = useContext(CategoryContext);
const onClick = (e) => {
let copyObject = { ...cateObject };
copyObject[value] = !checked;
setCateObject(copyObject);
}
return (
checked && (
<button onClick={onClick} value={value}>
<p>{value}</p>
<p>×</p>
</button>
)
);
};
export default Selected;
๋ฒํผ ์ปดํฌ๋ํธ๋ ๊ฐ๋จํฉ๋๋ค.
CheckboxList์์ ์ ๋ฌํด ์ค value์ ํจ๊ป ๋ฒํผ์ ์ถ๋ ฅํ๊ณ onClick ์ด๋ฒคํธ๋ฅผ ๋ฌ์ ์ฃผ๊ธฐ๋ง ํ๋ฉด ๋๋๋ฐ์.
onClick ํจ์์์๋ true์ธ checked
์์ฑ์ false
๋ก ๋ฐ๊ฟ ์ฃผ๊ธฐ๋ง ํ๋ฉด ๋ฉ๋๋ค.
๊ทธ๋ฆฌ๊ณ checked๊ฐ true์ผ ๋๋ง ๋ฒํผ์ด ๋ง๋ค์ด์ง๋๋ก ์กฐ๊ฑด์ ๋ถ์ฌ ์ค์๋ค.
๊ทธ๋ฌ๋ฉด ์ด๋ ๊ฒ ๋ฒํผ์ผ๋ก๋ ์ฒดํฌ๋ฐ์ค๊ฐ ํด์ ๋๋ ๋ชจ์ต์ ๋ณด์ค ์ ์์ต๋๋ค~
์ ๋ ์คํ์ผ๋ง๋ ๋ฃ์ด ์คฌ๋๋ฐ, ์คํ์ผ๋ง์ด ํฌํจ๋ ์ ์ฒด ์ฝ๋๊ฐ ๊ถ๊ธํ์๋ค๋ฉด ๋งํฌ๋ฅผ ์ฐธ๊ณ ๋ถํ๋๋ ค์.
GitHub - ttaerrim/product-admin: ์ํ๋ฑ๋ก ๊ณผ์ ๊ตฌํ ๋ด์ฉ์ ๋ด์ ๋ ํฌ์งํ ๋ฆฌ์ ๋๋ค
์ํ๋ฑ๋ก ๊ณผ์ ๊ตฌํ ๋ด์ฉ์ ๋ด์ ๋ ํฌ์งํ ๋ฆฌ์ ๋๋ค. Contribute to ttaerrim/product-admin development by creating an account on GitHub.
github.com
์ด ํฌ์คํ ์์๋ ๊ฐ์ฒด ํํ๋ก Checkbox ์ํ ๊ด๋ฆฌ๋ฅผ ํด ๋ดค๋๋ฐ, isAllFalse๋ฅผ ์ฒดํฌํ๋ ๊ณผ์ ์์ ๊ฐ์ด ๋ง์์ง๋ค๋ฉด ์๊ฐ ๋ณต์ก๋๊ฐ ๋์์ง ๊ฒ ๊ฐ์ ๋ฐฐ์ด๋ก ๊ด๋ฆฌํ๋ ๊ฒ ๋ ์ข์ ๊ฒ ๊ฐ๋ค๋ ์๊ฐ์ด ๋ญ๋๋ค. ๋ฐฐ์ด๋ก๋ ๋ ๊ฐํธํ๊ฒ ์ํ ๊ด๋ฆฌ๋ฅผ ํ ์ ์์ผ๋ ์ฐธ๊ณ ํด ์ฃผ์๊ธธ ๋ฐ๋ผ์.
์ ๊ฐ ๊ฒ์ํ์ ๋๋ ์๋ฌด๋ฆฌ ์ฐพ์๋ด๋ ๋ฒํผ์ผ๋ก ์ฒดํฌ๋ฐ์ค ์ ํ ํด์ ํ๋ ๋ฐฉ๋ฒ์ด ๋๋ฌด์ง ๋ณด์ด์ง ์์ ์ฐ๊ฒ ๋ ํฌ์คํธ์ด๊ธฐ๋ ํฉ๋๋ค. ๐ฅฒ
๋์์ด ๋์ จ๋ค๋ฉด ์ ์๊ฒ ํ์ด ๋๋ ๊ณต๊ฐ ๋ฒํผ์ด๋ ๋๊ธ ๋ถํ๋๋ ค์. (--)(__)