Start React project - 프로젝트만들기
JSX Example - 컴포넌트를 만드는 법과 JSX문법
state and props - State와 props
리엑트에서 배열에 원소를 제거하는 예제
리액트애서는 state 내부의 값을 직접적으로 수정하면 절대로 안되며 이를 불변성 유지라고 한다.
push, splice, unshift, pop 같은 내장함수는 배열 자체를 직접 수정하게 되므로 적합하지 않다.
그 대신에, 기존의 배열에 기반하여 새 배열을 만들어내는 함수인 concat, slice, map, filter 같은 함수를 사용해야한다.
send me email if you have any questions.
배열 항목 제거하기
import React from 'react';
function User({ user, onRemove }) {
return (
<div>
<b>{user.username}</b> <span>({user.phonenumber})</span>
<button onClick={() => onRemove(user.id)}>삭제</button>
</div>
)
}
function UserList({ users, onRemove }) {
return (
<div>
{users.map(user => (
<User user={user} key={user.id} onRemove={onRemove} />
))}
</div>
);
}
export default UserList;
UserList.js
각 User 컴포넌트를 보여줄 때, 삭제버튼도 함께 랜더링하도록 코드수정.
onRemove는 App.js에서 구현
import React, { useRef, useState } from 'react';
import UserList from './components/UserList';
import CreateUser from './components/CreateUser';
function App() {
const [users, setUsers] = useState([
{
id: 1,
username: '임준호',
phonenumber: '010-0000-0000'
},
{
id: 2,
username: 'testuser1',
phonenumber: '010-1234-1234'
},
{
id: 3,
username: 'testuser2',
phonenumber: '010-2222-4444'
}
]);
const [inputs, setInputs] = useState({
username: '',
phonenumber: ''
});
const { username, phonenumber } = inputs;
const onChange = e => {
const { name, value } = e.target;
setInputs({
...inputs,
[name]: value
});
};
const nextId = useRef(4);
const onCreate = () => {
const user = {
id : nextId.current,
username,
phonenumber
};
setUsers(users.concat(user))
setInputs({
username: '',
phonenumber: ''
});
nextId.current += 1;
}
const onRemove = id => {
setUsers(users.filter(user => user.id !== id));
}
return (
<div>
<CreateUser
username={username}
phonenumber={phonenumber}
onChange={onChange}
onCreate={onCreate}
/>
<UserList users={users} onRemove={onRemove} />
</div>
);
}
export default App;
App.js
onRemove를 구현
-> user.id가 일치하지 않는 원소들로 새로운 배열을 만든다.
useRef Example
useRef는 위의 정리글 참고
예제 실행결과
PREVIOUSArrow function(화살표함수)