๋ฐ˜์‘ํ˜•

์ „์ฒด ๊ธ€ 293

[Java] ์ƒ์†

์ด ๊ธ€์€ ์ƒํ™œ์ฝ”๋”ฉ์˜ 'Java' ๊ฐ•์ขŒ๋ฅผ ๋ฐ”ํƒ•์œผ๋กœ ์ •๋ฆฌํ•œ ๋‚ด์šฉ์ž…๋‹ˆ๋‹ค. ์ƒ์†์ด๋ž€? ๊ฐ์ฒด ์ง€ํ–ฅ์—์„œ ๊ฐ€์žฅ ์ค‘์š”ํ•œ ๋ชฉํ‘œ ์ค‘ ํ•˜๋‚˜๋Š” ๋ฐ”๋กœ ์žฌํ™œ์šฉ์„ฑ์ž…๋‹ˆ๋‹ค. ์ƒ์†์€ ๊ฐ์ฒด์ง€ํ–ฅ์˜ ์žฌํ™œ์šฉ์„ฑ์„ ๊ทน๋Œ€ํ™”์‹œํ‚จ ํ”„๋กœ๊ทธ๋ž˜๋ฐ ๊ธฐ๋ฒ•์ด๋ผ๊ณ  ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ๋™์‹œ์— ๊ฐ์ฒด ์ง€ํ–ฅ์„ ๋ณต์žกํ•˜๊ฒŒ ํ•˜๋Š” ์ฃผ์š” ์›์ธ์ด๋ผ๊ณ ๋„ ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ์ƒ์†(Inheritance)์ด๋ž€ ๋ฌผ๋ ค์ค€๋‹ค๋Š” ์˜๋ฏธ์ž…๋‹ˆ๋‹ค. ์–ด๋–ค ๊ฐ์ฒด๊ฐ€ ์žˆ์„ ๋•Œ ๊ทธ ๊ฐ์ฒด์˜ ํ•„๋“œ(๋ณ€์ˆ˜)์™€ ๋ฉ”์†Œ๋“œ๋ฅผ ๋‹ค๋ฅธ ๊ฐ์ฒด๊ฐ€ ๋ฌผ๋ ค๋ฐ›์„ ์ˆ˜ ์žˆ๋Š” ๊ธฐ๋Šฅ์„ ์ƒ์†์ด๋ผ๊ณ  ํ•ฉ๋‹ˆ๋‹ค. package org.opentutorials.javatutorials.object; class Calculator{ int left, right; public void setOprands(int left, int right){ this.left = l..

Programming/Java 2022.10.24

[Java] ์ดˆ๊ธฐํ™”์™€ ์ƒ์„ฑ์ž

์ด ๊ธ€์€ ์ƒํ™œ์ฝ”๋”ฉ์˜ 'Java' ๊ฐ•์ขŒ๋ฅผ ๋ฐ”ํƒ•์œผ๋กœ ์ •๋ฆฌํ•œ ๋‚ด์šฉ์ž…๋‹ˆ๋‹ค. ์ดˆ๊ธฐํ™” ์–ด๋–ค ์ผ์„ ์‹œ์ž‘ํ•˜๊ธฐ ์ „์— ์ค€๋น„ํ•˜๊ฒŒ ๋˜๋Š”๋ฐ, ์ด๋ฅผ ์ดˆ๊ธฐํ™”๋ผ๊ณ  ํ•ฉ๋‹ˆ๋‹ค. ๊ฐ์ฒด ์ง€ํ–ฅ ํ”„๋กœ๊ทธ๋ž˜๋ฐ๋„ ์ดˆ๊ธฐํ™”์— ํ•ด๋‹นํ•˜๋Š” ๊ธฐ๋Šฅ์ด ์ œ๊ณต๋˜๋Š”๋ฐ ์ด๋ฅผ ์ƒ์„ฑ์ž (constructor)๋ผ๊ณ  ํ•ฉ๋‹ˆ๋‹ค. ์•ž์„œ ์‚ดํŽด๋ดค๋˜ ๊ณ„์‚ฐ๊ธฐ ์˜ˆ์ œ๋ฅผ ๋‹ค์‹œ ๋ด…์‹œ๋‹ค. Calculator c1 = new Calculator(); c1.setOprands(10, 20); c1.sum(); c1.avg(); ๋ฉ”์†Œ๋“œ setOperands์˜ ๊ฐ’์œผ๋กœ 10๊ณผ 20์„ ์ง€์ •ํ–ˆ์Šต๋‹ˆ๋‹ค. ์ด๋Š” ๊ฐ์ฒด ๋‚ด๋ถ€์—์„œ ์ธ์Šคํ„ด์Šค ๋ณ€์ˆ˜ left๊ณผ right์˜ ๊ฐ’์œผ๋กœ ์„ค์ •๋˜์–ด ์œ ์ง€๋ฉ๋‹ˆ๋‹ค. ํ•˜์ง€๋งŒ ์•„๋ž˜์™€ ๊ฐ™์ด ๋ฉ”์†Œ๋“œ setOperands ํ˜ธ์ถœํ•˜๊ธฐ ์ „์— sum๊ณผ avg๋ฅผ ํ˜ธ์ถœํ•œ๋‹ค๋ฉด ์›ํ•˜๋Š” ๊ฒฐ๊ณผ๋ฅผ ์–ป์„ ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค. C..

Programming/Java 2022.10.24

[React ์™„๋ฒฝ ๊ฐ€์ด๋“œ] section 11 : Practice Project: Building a Food Order App

์ด ๊ธ€์€ udemy์˜ React ์™„๋ฒฝ ๊ฐ€์ด๋“œ with Redux, Next.js, TypeScript ๊ฐ•์ขŒ๋ฅผ ๋ฐ”ํƒ•์œผ๋กœ ์ •๋ฆฌํ•œ ๋‚ด์šฉ์ž…๋‹ˆ๋‹ค. 139. ๋ชจ๋“ˆ ์†Œ๊ฐœ ์ง€๋‚œ ์„น์…˜์—์„œ ์ค‘์š”ํ•œ ๋ฆฌ์•กํŠธ ๊ฐœ๋…๋“ค์„ ์‚ดํŽด๋ณด์•˜์Šต๋‹ˆ๋‹ค. useEffect, useContext, useReducer ๋“ฑ๋“ฑ / ์œ„ ๊ฐœ๋…์„ ๋ณต์Šตํ•˜๋ฉด์„œ ๋‹ค์‹œ ์‚ดํŽด๋ณด๋„๋ก ํ•ฉ์‹œ๋‹ค. 140. ์„ค์ • ์‹œ์ž‘ํ•˜๊ธฐ Layout folder : ex. Header UI folder: ex. Input 141. "ํ—ค๋”" ์ปดํฌ๋„ŒํŠธ ์ถ”๊ฐ€ํ•˜๊ธฐ header ์ปดํฌ๋„ŒํŠธ ์ถ”๊ฐ€ 142. Adding the "Cart" Button Component Cart Button ์ปดํฌ๋„ŒํŠธ ์ถ”๊ฐ€ 143. Adding a "Meals" Component Meals ์ปดํฌ๋„ŒํŠธ ์ถ”๊ฐ€ 144. Adding I..

[React ์™„๋ฒฝ ๊ฐ€์ด๋“œ] section 10 : ๊ณ ๊ธ‰ ๋ฆฌ๋“€์„œ(Reducer)๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ๋ถ€์ž‘์šฉ ์ฒ˜๋ฆฌ & ์ปจํ…์ŠคํŠธ API

์ด ๊ธ€์€ udemy์˜ React ์™„๋ฒฝ ๊ฐ€์ด๋“œ with Redux, Next.js, TypeScript ๊ฐ•์ขŒ๋ฅผ ๋ฐ”ํƒ•์œผ๋กœ ์ •๋ฆฌํ•œ ๋‚ด์šฉ์ž…๋‹ˆ๋‹ค. 117. ๋ชจ๋“ˆ ์†Œ๊ฐœ Effects, ReducersContext Working with (Side) Effects MAnaging more Complex State with Reducers Managing App - Wide or Component - Wide State with Context 118. "Side Effects"์ด๋ž€ ๋ฌด์—‡์ด๋ฉฐ useEffect๋ฅผ ์†Œ๊ฐœํ•ฉ๋‹ˆ๋‹ค. Main Job : Render UI & React to User Input Evaluate & Render JSX Manage State & Props React to (User) Events & ..

[JavaScript] ์ต๋ช…ํ•จ์ˆ˜(Anonymous function) ๋ž€ ๋ฌด์—‡์ธ๊ฐ€?

Intro javascript์˜ ์ต๋ช…ํ•จ์ˆ˜์— ๋Œ€ํ•ด ์•Œ์•„๋ณด๋„๋ก ํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค. Anonymous function ์ต๋ช… ํ•จ์ˆ˜๋Š” ์—ฐ๊ฒฐ๋œ ์ด๋ฆ„์ด ์—†๋Š” ํ•จ์ˆ˜์ž…๋‹ˆ๋‹ค. ์ผ๋ฐ˜์ ์œผ๋กœ JavaScript์—์„œ ํ•จ์ˆ˜๋ฅผ ์ •์˜ํ•˜๊ธฐ ์œ„ํ•ด ํ•จ์ˆ˜ ์ด๋ฆ„ ์•ž์— function ํ‚ค์›Œ๋“œ๋ฅผ ์‚ฌ์šฉํ•˜์ง€๋งŒ JavaScript์˜ ์ต๋ช… ํ•จ์ˆ˜์—์„œ๋Š” ํ•จ์ˆ˜ ์ด๋ฆ„ ์—†์ด function ํ‚ค์›Œ๋“œ๋งŒ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. ์ต๋ช… ํ•จ์ˆ˜๋Š” ์ฒ˜์Œ ์ƒ์„ฑ๋œ ํ›„์—๋Š” ์ ‘๊ทผํ•  ์ˆ˜ ์—†์œผ๋ฉฐ ๊ฐ’์œผ๋กœ ํ•จ์ˆ˜๋กœ ์ €์žฅ๋œ ๋ณ€์ˆ˜๋กœ๋งŒ ์ ‘๊ทผํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ์ต๋ช… ํ•จ์ˆ˜๋Š” ์—ฌ๋Ÿฌ ์ธ์ˆ˜๋ฅผ ๊ฐ€์งˆ ์ˆ˜๋„ ์žˆ์ง€๋งŒ ํ•˜๋‚˜์˜ ํ‘œํ˜„์‹๋งŒ ๊ฐ€์งˆ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. Syntax function() { // Function Body } → function ํ‚ค์›Œ๋“œ๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ์„ ์–ธํ•˜์˜€์Šต๋‹ˆ๋‹ค. ( () => { // Function Body... } )..

[Html] input tag ์ตœ์†Œ๊ฐ’(min)๊ณผ ์ตœ๋Œ€๊ฐ’(max) ์„ค์ •ํ•˜๋Š” ๋ฐฉ๋ฒ•

Intro input tag ์—์„œ ์ตœ์†Œ๊ฐ’๊ณผ ์ตœ๋Œ€๊ฐ’์„ ์„ค์ •ํ•˜๋Š” ๋ฐฉ๋ฒ•์— ๋Œ€ํ•ด ์•Œ์•„๋ณด๋„๋ก ํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค. Syntax ์ˆซ์ž (number) : ์ตœ์†Ÿ๊ฐ’ ํ˜น์€ ์ตœ๋Œ€๊ฐ’์„ ๋ช…์‹œํ•จ ๋‚ ์งœ (date) : ์ตœ์†Ÿ๊ฐ’ ํ˜น์€ ์ตœ๋Œ€๊ฐ’์„ ๋ช…์‹œํ•จ Example http://www.tcpschool.com/html-tag-attrs/input-min

Programming/Html 2022.10.07

[Kotlin] ์ด์Šค์ผ€์ดํ”„ ๋ฌธ์ž (escape character) ์™€ RAW ๋ฌธ์ž์—ด

Intro ์ฝ”ํ‹€๋ฆฐ์—์„œ์˜ ์ด์Šค์ผ€์ดํ”„ ๋ฌธ์ž (escape character), ๊ทธ๋ฆฌ๊ณ  Raw์— ๋Œ€ํ•ด ์•Œ์•„๋ณด๋„๋ก ํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค. Escape character ์ด์Šค์ผ€์ดํ”„ ๋ฌธ์ž๋ž€, ๋ฌธ์ž์—ด ๋‚ด์—์„œ ํŠน์ˆ˜ํ•œ ๊ธฐ๋Šฅ์„ ์ˆ˜ํ–‰ํ•˜๋Š” ๋ฌธ์ž์ž…๋‹ˆ๋‹ค. ์—ญ์Šฌ๋ž˜์‹œ(\) ๊ธฐํ˜ธ๊ฐ€ ๋ถ™์€ ํŠน์ˆ˜ํ•œ ๊ธฐ๋Šฅ์„ ํ•˜๋Š” ๋ฌธ์ž ๋ฆฌํ„ฐ๋Ÿด ์ž…๋‹ˆ๋‹ค. ์ฆ‰ ๋ฌธ์ž์—ด ์•ˆ์—์„œ ํŠน๋ณ„ํ•œ ์˜๋ฏธ๋กœ ํ•ด์„๋˜๋Š” ๋ฌธ์ž์ž…๋‹ˆ๋‹ค. ๊ตฌ๋ถ„ ์˜๋ฏธ \a ๊ฒฝ๊ณ ์Œ ์ถœ๋ ฅ \n ์ค„ ๋ฐ”๊ฟˆ, ๊ฐœํ–‰ (new line) \t ์ˆ˜ํ‰ ํƒญ์œผ๋กœ ์ผ์ •ํ•œ ๊ฐ€๊ฒฉ ๋„์šฐ๊ธฐ, ํƒญ (tab) \b ๋ฐฑ์ŠคํŽ˜์ด์Šค๋กœ ๋’ค๋กœ ํ•œ ์นธ ์ด๋™ (backspace) \r ๋™์ผํ•œ ์ค„์˜ ๋งจ ์•ž ์นธ์œผ๋กœ ์ปค์„œ ์ด๋™ (carriage return) \f ์ถœ๋ ฅ ์šฉ์ง€๋ฅผ ํ•œ ํŽ˜์ด์ง€ ๋„˜๊น€ (form feed) \\ \(์—ญ์Šฌ๋ž˜์‹œ) ๋ฌธ์ž ์ถœ๋ ฅ \' '์ž‘์€ ๋”ฐ์Œํ‘œ ๋ฌธ์ž ์ถœ๋ ฅ..

Programming/Kotlin 2022.10.05

[JavaScript] Axios ์˜ค๋ฅ˜ ์ฒ˜๋ฆฌ / catch ๋ฌธ์—์„œ Status Code ๋ฐ›์•„์˜ค๋Š” ๋ฐฉ๋ฒ•

Intro Axios์˜ catch() ๋ฌธ์—์„œ Status Code ๋ฅผ ๋ฐ›์•„์˜ค๋Š” ๋ฐฉ๋ฒ•์— ๋Œ€ํ•ด ์•Œ์•„๋ณด๋„๋ก ํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด ๋‹ค์Œ์˜ axios ์š”์ฒญ์ด ์žˆ๋‹ค๊ณ  ๊ฐ€์ •ํ•ด ๋ด…์‹œ๋‹ค. axios .get('foo.example') .then((response) => {}) .catch((error) => { console.log(error); //Logs a string: Error: Request failed with status code 404 }); ๋‹ค์Œ์˜ ๋ฐฉ๋ฒ•์œผ๋กœ console.log ๋กœ ์ฐ์–ด๋ณผ ๊ฒฝ์šฐ ๋‹จ์ˆœ string ๋งŒ ๋ฐ˜ํ™˜ํ•˜๊ฒŒ ๋ฉ๋‹ˆ๋‹ค. return ๋œ object๋ฅผ ๋ฐ›๊ณ  ์‹ถ์„ ๊ฒฝ์šฐ ์–ด๋–ป๊ฒŒ ํ•ด์•ผ ํ• ๊นŒ์š”? How to solve the problem axios.get('/foo') .catch(functio..

[Next.js] url ๋กœ ํŠน์ • page์— ์ง์ ‘ ์ ‘๊ทผ ๋ง‰๋Š” ๋ฐฉ๋ฒ•

Intro Next.js๋กœ ๊ตฌํ˜„๋œ ํ”„๋กœ์ ํŠธ์—์„œ ํŠน์ • ํŽ˜์ด์ง€๋“ค์„ ์ˆจ๊ธฐ๋Š” ์š”์ฒญ์‚ฌํ•ญ์ด ๋“ค์–ด์™”์Šต๋‹ˆ๋‹ค. ๋ณดํ†ต Next.js๋Š” pages๋ผ๋Š” ํด๋” ํ•˜์œ„์— ํŒŒ์ผ ํ˜น์€ ํด๋“œ๋ฅผ ์ž‘์„ฑํ•˜๊ฒŒ ๋˜๋ฉด ํ•ด๋‹น ํŒŒ์ผ/ํด๋”๋ฅผ ์ž๋™์œผ๋กœ ๋ผ์šฐํŒ… ํ•ด์ค๋‹ˆ๋‹ค. ์ฒ˜์Œ ๋‹จ์ˆœํ•˜๊ฒŒ NavBar ๋„ค๋น„๋ฐ”์— ์žˆ๋Š” ํŠน์ • link tag ๋ฅผ ์ฃผ์„์ฒ˜๋ฆฌํ–ˆ์ง€๋งŒ, url๋กœ ํ•ด๋‹น ํŽ˜์ด์ง€ ์ง์ ‘ ์ ‘๊ทผ์‹œ ์ ‘๊ทผ์ด ๊ฐ€๋Šฅํ–ˆ์Šต๋‹ˆ๋‹ค. How to do Next.js์˜ ๊ณต์‹ ๋ฌธ์„œ๋ฅผ ์‚ดํŽด๋ณด๋ฉด, Next.js๋Š” Redirects๋ผ๋Š” ๊ธฐ๋Šฅ์„ ์ œ๊ณตํ•˜๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค. ์œ„ ๊ธฐ๋Šฅ์€ Next.js ํ”„๋กœ์ ํŠธ ํด๋” root์— ์žˆ๋Š” next.config.js ํŒŒ์ผ์—์„œ ์„ค์ •ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. Redirects Redirects allow you to redirect an incoming request path ..

Framework/Next.js 2022.10.03

[React] React.FC ์˜ ์˜๋ฏธ์™€ ์‚ฌ์šฉํ•˜์ง€ ์•Š๋Š” ์ด์œ 

Intro React.FC์˜ ์˜๋ฏธ์™€ ์‚ฌ์šฉํ•˜์ง€ ์•Š๋Š” ์ด์œ ์— ๋Œ€ํ•ด ์•Œ์•„๋ณด๋„๋ก ํ•˜๊ฒ ์Šต๋‹ˆ๋‹ค. type Props = { }; const TestComponent: React.FC = () => { return ( TestComponent ); }; export default TestComponent; ํ˜„์žฌ React typescript๋ฅผ ์‚ฌ์šฉํ•˜๊ณ  ์žˆ๋Š” ํ”„๋กœ์ ํŠธ์—์„œ ์ปดํฌ๋„ŒํŠธ๋ฅผ ์ž‘์„ฑํ•  ๋•Œ ๋‹ค์Œ๊ณผ ๊ฐ™์€ ๋ฐฉ๋ฒ•์„ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. FC๋ฅผ ์‚ฌ์šฉํ•˜์ง€ ๋ง์•„์•ผ ํ•˜๋Š” ์ด์œ  ํ•˜์ง€๋งŒ ๐Ÿคจ React typescript๋Š” ๊ทธ๋‹ค์ง€ ์ข‹์€ ๋ฐฉ๋ฒ•์ด๋ผ๊ณ  ํ•ฉ๋‹ˆ๋‹ค. ๊ทธ์ค‘์—์„œ ๊ฐ€์žฅ ํฐ ์ด์œ ๋Š” props์ด ์•”์‹œ์ ์œผ๋กœ ๋“ค์–ด๊ฐ€ ์žˆ๊ธฐ ๋•Œ๋ฌธ์ž…๋‹ˆ๋‹ค. children์„ ์•”์‹œ์ ์œผ๋กœ ๊ฐ€์ง€๊ณ  ์žˆ์Šต๋‹ˆ๋‹ค. ์ œ๋„ค๋ฆญ์„ ์ง€์›ํ•˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค. ๋„ค์ž„ ์ŠคํŽ˜์ด์Šค ํŒจํ„ด์„ ์ด์šฉํ•  ๋•Œ ๋” ๋ถˆํŽธํ•ฉ..

Framework/React 2022.10.02
๋ฐ˜์‘ํ˜•