React 101 - 파트 1: 첫 번째 단계
13471 단어 tutorialreactjavascriptbeginners
이제 React 학습 여정을 시작할 준비가 되었습니다 :)
아무것도 놓치고 싶지 않다면 팔로우를 클릭하세요. 전날 React 과정에서 배운 내용을 여기 Dev.to에 게시할 예정입니다.
더 이상 고민하지 않고 여기에 1일차 메모를 요약했습니다.
반응이란 무엇입니까?
React는 사용자 인터페이스(프론트엔드 애플리케이션)를 구축하기 위한 Javascript 라이브러리입니다.
React는 애플리케이션 상태의 변화에 따라 진화할 수 있는 요소를 사용하여 인터페이스를 나타낼 수 있는 라이브러리입니다.
React는 2개의 개별 요소로 사물을 분리할 수 있습니다.
응용 프로그램의 상태를 저장하고 다양한 사용자 상호 작용에 따라 수정할 수 있는 상태입니다.
애플리케이션의 상태에 따라 새로운 버전의 인터페이스를 렌더링하는 render() 함수.
더 이상 DOM의 변경 사항을 처리하지 않습니다. 애플리케이션의 상태가 변경될 때마다 React는 render() 함수를 다시 시작하고 DOM 수준에서 변경 사항을 적용합니다.
반응 첫 단계
가능한 한 빨리 학습을 시작하기 위해 지금은 React 및 React DOM 라이브러리 CDN 링크만 포함합니다. 나중에 실제 프로덕션 React 앱을 올바르게 시작하는 방법을 배우게 됩니다.
나는 또한 세 번째 파일(app.js)을 포함할 것이고 그것은 우리의 로컬 Javascript/React 코드가 될 것입니다.
defer 속성은 페이지 html이 로드된 후 해당 스크립트의 로드를 연기합니다.
또한 본문 안에 id="app"가 있는 div를 넣습니다. 해당 div는 React App의 컨테이너가 됩니다.
index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script crossorigin src="https://unpkg.com/react@17/umd/react.development.js" defer></script>
<script crossorigin src="https://unpkg.com/react-dom@17/umd/react-dom.development.js" defer></script>
<script src="app.js" defer></script>
</head>
<body>
<div id="app">
</div>
</body>
</html>
첫 번째 단계에서는 Hello World h1 태그를 만들고 요소를 앱 컨테이너에 연결합니다.
app.js
// Create a new React element
const title = React.createElement('h1', {}, 'Hello World')
// Render this element in the div id="app"
ReactDOM.render(title, document.querySelector('#app'))
첫 번째 React 앱... 더 잘할 수 있기를 바랍니다 ;-)
이 예제(React.createElement)는 실제 환경에서 사용할 것이 아닙니다. 이 방법은 React가 백그라운드에서 DOM을 조작하는 방법을 보여주기 위해서만 사용합니다.
실제 React 앱에서는 JSX 구문을 사용합니다. JSX 구문을 사용하면 동일한 작업을 수행할 수 있지만 다른 구문을 사용할 수 있습니다.
JSX란 무엇입니까?
JSX는 JavaScript XML을 나타냅니다. JSX를 사용하면 React에서 HTML을 작성할 수 있습니다. JSX를 사용하면 React에서 HTML을 더 쉽게 작성하고 추가할 수 있습니다.
JSX를 사용하면 JavaScript로 HTML 요소를 작성하고 createElement() 및/또는 appendChild() 메서드 없이 DOM에 배치할 수 있습니다.
JSX는 HTML 태그를 반응 요소로 변환합니다.
JSX를 반드시 사용해야 하는 것은 아니지만 JSX를 사용하면 React 애플리케이션을 더 쉽게 작성할 수 있습니다.
JSX는 브라우저에서 읽을 수 없으므로 JSX를 실행하기 전에 표준 자바스크립트로 변환해야 합니다.
Babel은 바로 그런 일을 해 주는 도구입니다. 모든 JSX 스크립트를 사용하여 모든 브라우저에서 읽을 수 있는 표준 자바스크립트로 변환할 수 있습니다.
Babel을 빠르게 설치하려면 index.html 헤드에 Babel CDN에 대한 링크를 추가할 수 있습니다. 나중에 우리는 로컬 컴퓨터에 이러한 모든 도구를 설치하는 방법을 배웁니다.
<script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script>
다음은 JSX의 예입니다.
const title = <h1>Hello World</h1>
ReactDOM.render(title, document.querySelector('#app'))
도전을 조금 더 추진하고 JSX 내에서 변수 이름을 표시할 수 있습니다.
const name = 'Mike'
// To use the variable name use the syntax {variableName}
function render() {
const title = <h1>
Hello {name}
</h1>
ReactDOM.render(title, document.querySelector('#app'))
}
render()
실제로 { } 내에서 모든 js 표현식을 사용할 수 있습니다.
function render() {
const title = <h1>
Hello {name.toUpperCase()}
</h1>
ReactDOM.render(title, document.querySelector('#app'))
}
render()
모든 자바스크립트 표현식이 유효합니다. 짝수 루프. 예를 들어 items.map은 항목 목록을 생성합니다.
const items = ['Item 1', 'Item 2', 'Item 3', 'Item 4']
function render() {
const title =
<div>
<ul>
{items.map((item) => <li>{item}</li>)}
</ul>
</div>
ReactDOM.render(title, document.querySelector('#app'))
}
render()
나중에 이 목록을 참조하려는 경우. 예를 들어 항목을 제거하면 React는 각 목록 항목을 고유하게 식별하는 방법이 필요합니다. 그런 이유로 맵을 사용할 때 참조 키를 설정합니다.
const items = ['Item 1', 'Item 2', 'Item 3', 'Item 4']
function render() {
const title =
<div>
<ul>
{items.map((item, key) => <li key={key}>{item}</li>)}
</ul>
</div>
ReactDOM.render(title, document.querySelector('#app'))
}
render()
결론
오늘은 여기까지입니다. 아직 배워야 할 것이 많으니 내일 뵙겠습니다... 하나도 놓치지 않으려면 팔로우를 눌러주세요!
트위터에서 나를 팔로우하세요:
Reference
이 문제에 관하여(React 101 - 파트 1: 첫 번째 단계), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/ericchapman/react-101-part-1-first-steps-1aah텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)