์ผ | ์ | ํ | ์ | ๋ชฉ | ๊ธ | ํ |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- ํ๋ก๊ทธ๋๋จธ์ค ๊ฑฐ๋ฆฌ๋๊ธฐ ํ์ธํ๊ธฐ
- ๊ตฌ๋ฆํค ์ฑ๋ฆฐ์ง
- app router emotion
- ๋ฐฑ์ค 1339๋ฒ js
- emtion app router
- ๋ฐฑ์ค 2108 nodejs
- ๋ฐฑ์ค 1339๋ฒ ์๋ฐ์คํฌ๋ฆฝํธ
- ๊ตฌ๋ฆํค ์ฑ๋ฆฐ์ง ํ๊ณ
- js ์ค์ฝํ
- ์นด์นด์ค ์ฝํ
- ๋ฐฑ์ค 1339๋ฒ nodejs
- ์ฌ์ฉ์ฑ ๊ฐ์
- ์๋ฐ์คํฌ๋ฆฝํธ ์ค์ฝํ
- ์ค์ฝํ
- TypeError: createContext only works in Client Components. Add the "use client" directive at the top of the file to use it. Read more:
- ๊ตฌ๋ฆํค
- ํ๋ก๊ทธ๋๋จธ์ค ๋ฌธ์์ด ์์ถ
- ์๋ฐ์คํฌ๋ฆฝํธ ๋ฌธ์์ด ์์ถ
- suspense ๋ณ๋ชฉํ์
- emotion RSC
- ๋ฆฌ์กํธ์ฟผ๋ฆฌ suspense
- js ๊ฑฐ๋ฆฌ๋๊ธฐ ํ์ธํ๊ธฐ
- next13 emotion
- js
- suspense ๋์์๋ฆฌ
- suspense ๋น๋๊ธฐ
- js ๋ฌธ์์ด ์์ถ
- ์ต์ ๋์ฒด์ด๋
- ๋ฐฑ์ค 2108 ์๋ฐ์คํฌ๋ฆฝํธ
- suspense react-query
- Today
- Total
Lennon FE
[React] React ๊ธฐ๋ณธ - JSX ๋ฌธ๋ฒ ๋ณธ๋ฌธ
JSX ๋ฌธ๋ฒ์ด๋?
๋ฆฌ์กํธ์์ ์๊น์๋ฅผ ์ ์ํ ๋, ์ฌ์ฉํ๋ ๋ฌธ๋ฒ์ด๋ค. HTML๊ณผ ์ ์ฌํ๊ฒ ์๊ฒผ์ง๋ง ์ค์ ๋ก๋ JavaScript์ด๋ค!
const App = () => {
return <div>Hello React!</div>
}
์ค์ JavaScript๊ฐ ์๋๋ฐ ๋ธ๋ผ์ฐ์ ๊ฐ ์ด๋ป๊ฒ ์ฝ๋๋ฅผ ํด์ํ๋ ๊ฑธ๊น?
์ฌ๊ธฐ์ Babel์ ๋ํด ์์๋ณด์.
Babel์ JSX๋ฅผ ๋ธ๋ผ์ฐ์ ๊ฐ ์ดํดํ ์ ์๋๋ก JavaScript๋ก ๋ณํํด์ค๋ค.
๊ทธ๋ฌ๋ JSX๊ฐ JavaScript๋ก ์ค๋ฅ ์์ด ์ ๋๋ก ๋ณํ๋๋ ค๋ฉด ๊ท์น์ ์ง์ผ์ผ ํ๋ค.
1. ํ๊ทธ๋ ๊ผญ ๋ซํ ์์ด์ผ ํ๋ค.
const App = () => {
return (
<div>
<h1>Hello</h1>
<br>
<input>
</div>
)
}
<br> , <input> ๋ฑ ๋ณธ๋ HTML์์ ๋ซํ์๋ ํ๊ทธ๋ JSX์์ ๋ซ๋ ํ๊ทธ๊ฐ ์๋๋ค!
๋น์ฐํ ํ๊ทธ ์ง์ด ๋ง์ง ์์๋ ์ค๋ฅ๊ฐ ๋ฐ์ํ๋ค ( div์ ๋ซ๋ ํ๊ทธ๊ฐ ์๋ ๊ฒฝ์ฐ ๋ฑ๋ฑ.. )
const App = () => {
return (
<div>
<h1>Hello</h1>
<br />
<input />
</div>
)
}
์์ ๊ฐ์ด ์์ฑํด์ค์ผ ํ๋ค.
2. ํ๊ทธ๋ ๊ฐ์ธ์ ธ์ผ ํ๋ค!
const App = () => {
return (
<div>
<h1>Hello</h1>
</div>
<div>
<h1>Bye</h1>
</div>
)
}
์๋ง ์ ์ฝ๋๋ ์ค๋ฅ๋ฅผ ์ผ์ผํฌ ๊ฒ์ด๋ค.
๋ ๊ฐ์ ํ๊ทธ๊ฐ ํ์ ์์น์ ์์ ๋ ํด๋น ์ปดํฌ๋ํธ๋ ์ต์๋จ์ ํ๋์ ํ๊ทธ๋ก ๊ฐ์ธ์ ธ ์์ด์ผ ํ๋ค.
const App = () => {
return (
<>
<div>
<h1>Hello</h1>
</div>
<div>
<h1>Bye</h1>
</div>
</>
)
}
<div>, <main>, <article> ๋ฑ๋ ๋น์ฐํ ๋๋ฉฐ, ๋น ํ๊ทธ๋ก๋ ๋์ํ๋ ์ฐธ๊ณ ํ์.
3. ๋ด๋ถ์ JavaScript ๊ฐ์ ์ฌ์ฉํ ๋ ์ค๊ดํธ๋ก ๋ฌถ์ด์ฃผ์!
const App = () => {
const value = "Hello";
return (
<>
<div>
<h1>{value}</h1>
</div>
<div>
<h1>Bye</h1>
</div>
</>
)
}
return ๋ด๋ถ์์ JavaScript๊ฐ์ ์ฌ์ฉํ ๋ {}๋ก ๊ผญ ๋ฌถ์ด์ฃผ์!
4. html๊ณผ ์กฐ๊ธ ๋ค๋ฅธ ๋ฌธ๋ฒ
const App = () => {
return <div class="hi">Hello React!</div>
}
์ฐ๋ฆฌ์๊ฒ ์ต์ํ ์ ์ฝ๋๋ ์ฝ์์์ "ํน์ HTML์ ์์ฑ์ค์ด์ ๊ฐ์?" ๋ผ๋ฉฐ ์ค๋ฅ๋ฅผ ์ผ์ผํฌ ๊ฒ์ด๋ค.
JSX ๋ฌธ๋ฒ์์ class๋ className์ผ๋ก ์ฌ์ฉํด์ผํ๋ค!
์ฐธ๊ณ ๋ก input์ ์ ์ฉํ๋ label ํ๊ทธ๋ฅผ ์ฌ์ฉํ ๋ for ์์ฑ๋ htmlFor๋ก ์ฌ์ฉํด์ผํ๋ค!
'๐งโ๐ป Web > React' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[React] PostCSS์์ style๊ฐ์ root์ฒ๋ผ ์ฌ์ฉํ๋ ๋ฐฉ๋ฒ (2) | 2022.05.21 |
---|---|
[React] React Route์ ๋ํด ์์๋ณด์ (0) | 2022.05.19 |
[React] React ๊ธฐ๋ณธ - CRA (0) | 2022.04.12 |
[๋ฆฌ์กํธ, mongoose Error] ๊ฐ๋ฐ ์ค ์๋ฌ๋ฅผ ํ์ธํด๋ณด๊ณ ํด๊ฒฐํด๋ณด์ (2) | 2022.01.10 |
[๋ฆฌ์กํธ ์ฝ๋ ์ปจ๋ฒค์ ] ESLint, Prettier, airbnb style guide๋ก ์ค์ ํ๊ธฐ (0) | 2022.01.05 |