๐ก ์ํ๊ด๋ฆฌ ๋ก์ง์ ์ฌํ์ฉ ๊ฐ๋ฅ
๐ก ํจ์ํ์ผ๋ก ์์ฑํ๋ฏ๋ก ๋น๊ต์ ๋ช
๋ฃ
//FriendStatus.js
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.js
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>
);
}
//hooks.js
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;
}
โ
Custom Hook์ ์ ์ํ ๋๋ ํจ์ ์ด๋ฆ ์์ use๋ฅผ ๋ถ์
โ
ํ๋ก์ ํธ ๋ด์ hooks ๋๋ ํ ๋ฆฌ์ Custom Hook์ ์์น
โ
return ํ๋ ๊ฐ์ ์กฐ๊ฑด๋ถ๋ ์๋จ
//FriendStatus.js
function FriendStatus(props) {
//custom hook ์ ์ฉ
const isOnline = useFriendStatus(props.friend.id);
if (isOnline === null) {
return 'Loading...';
}
return isOnline ? 'Online' : 'Offline';
}
//FriendListItem.js
function FriendListItem(props) {
//custom hook ์ ์ฉ
const isOnline = useFriendStatus(props.friend.id);
return (
<li style={{ color: isOnline ? 'green' : 'black' }}>
{props.friend.name}
</li>
);
}
์ฝ๋์คํ
์ด์ธ ๊ต๊ณผ์
React-์์ ๋ง์ Hook ๋ง๋ค๊ธฐ