function Calculator({value}){
const result = calculate(value);
return <>
<div>
{result}
</div>
</>;
}
props๋ก ๋์ด์จ value๋ฅผ calculateํจ์์ ๋๊ฒจ์ result๊ตฌํ๊ณ ์ถ๋ ฅํ๋ ์ปดํฌ๋ํธ
์ฌ๊ธฐ์ calculateํจ์๊ฐ ๋ณต์กํ์ฐ์ฐ์ ํ๋ค๋ฉด ๋ ๋๋ง์ด ๊ธธ์ด์ง
/* useMemo๋ฅผ ์ฌ์ฉํ๊ธฐ ์ ์๋ ๊ผญ importํด์ ๋ถ๋ฌ์์ผ ํฉ๋๋ค. */
import { useMemo } from "react";
function Calculator({value}){
const result = useMemo(() => calculate(value), [value]);
return <>
<div>
{result}
</div>
</>;
}
๊ฐ๋ฐ์๊ฐ ์ค์ค๋ก ์ปค์คํ ํ ํ
์ฌ๋ฌ url์ fetchํ ๋, ์ฌ๋ฌ input์ ์ํ ์ํ ๋ณ๊ฒฝ ๋ฑ ๋ฐ๋ณต๋๋ ๋ก์ง์ ๋์ผํจ์์์ ์๋์ผํ๊ณ ์ถ์ ๋ ์ฌ์ฉํจ
์ด๋ฐ ์ปดํฌ๋ํธ๊ฐ ์๋ค๊ณ ์น์
//FriendStatus : ์น๊ตฌ๊ฐ online์ธ์ง offline์ธ์ง returnํ๋ ์ปดํฌ๋ํธ
function FriendStatus(props) {
const [isOnline, setIsOnline] = useState(null);
useEffect(() => {
function handleStatusChange(status) {
setIsOnline(status.isOnline);
}
ChatAPI.subscribeToFriendStatus(props.friend.id, handleStatusChange);
return () => {
ChatAPI.unsubscribeFromFriendStatus(props.friend.id, handleStatusChange);
};
});
if (isOnline === null) {
return 'Loading...';
}
return isOnline ? 'Online' : 'Offline';
}
//FriendListItem : ์น๊ตฌ๊ฐ online์ผ ๋ ์ด๋ก์์ผ๋ก ํ์ํ๋ ์ปดํฌ๋ํธ
function FriendListItem(props) {
const [isOnline, setIsOnline] = useState(null);
useEffect(() => {
function handleStatusChange(status) {
setIsOnline(status.isOnline);
}
ChatAPI.subscribeToFriendStatus(props.friend.id, handleStatusChange);
return () => {
ChatAPI.unsubscribeFromFriendStatus(props.friend.id, handleStatusChange);
};
});
return (
<li style={{ color: isOnline ? 'green' : 'black' }}>
{props.friend.name}
</li>
);
}
function useFriendStatus(friendID) {
const [isOnline, setIsOnline] = useState(null);
useEffect(() => {
function handleStatusChange(status) {
setIsOnline(status.isOnline);
}
ChatAPI.subscribeToFriendStatus(friendID, handleStatusChange);
return () => {
ChatAPI.unsubscribeFromFriendStatus(friendID, handleStatusChange);
};
});
return isOnline;
}