avatar

Page 28

  • javascript event bubbling & capturing

    ![image](https://miro.medium.com/max/1200/1*Et5UjVPGLfF1L43T7ErrxQ.png) ## Javascript Event Capturing https://codepen.io/yceffort/pen/GbVaaY Event Capturing์€ ํŠน์ • ์š”์†Œ์—์„œ ์ด๋ฒคํŠธ๊ฐ€ ๋ฐœ์ƒํ–ˆ์„ ๋•Œ, ์ตœ์ƒ์œ„ ์š”์†Œ์—์„œ ๋ถ€ํ„ฐ ์ด๋ฒคํŠธ๋ฅผ ํƒ...

    2๋ถ„
  • javascript class

    # Class ํด๋ž˜์Šค๋Š” ๊ธฐ๋ณธ์ ์œผ๋กœ ์ด๋ ‡๊ฒŒ ์ƒ๊ฒผ๋‹ค. ```javascript class Member { getName() { return "์ด๋ฆ„"; } } let obj = new Member(); console.log(obj.getName()); ``` ## ํŠน์ง• ### 1. strict ๋ชจ๋“œ์—์„œ ์‹คํ–‰ ๋”ฑํžˆ `'use strict'...

    3๋ถ„
  • Intersection Observer

    ## Intersection Observer Intersection Observer๋Š” ์—˜๋ฆฌ๋จผํŠธ๊ฐ€ viewport์— ๋…ธ์ถœ๋˜๊ณ  ์žˆ๋Š”์ง€ ์—ฌ๋ถ€๋ฅผ ํ™•์ธํ•ด์ฃผ๋Š” API๋‹ค. ๊ฐ„๋‹จํžˆ ๋งํ•ด ๋ธŒ๋ผ์šฐ์ €์˜ ์–ด๋–ค ์š”์†Œ๊ฐ€ ํ™”๋ฉด์— ๋…ธ์ถœ๋˜๊ณ  ์žˆ๋Š”์ง€ ์•ˆ๋˜๊ณ  ์žˆ๋Š”์ง€๋ฅผ ํ™•์ธํ•ด์ฃผ๋Š” ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋ผ๊ณ  ์ƒ๊ฐํ•˜๋ฉด ๋  ๊ฒƒ ๊ฐ™๋‹ค. ์ด ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๊ฐ€ ์—†์ด ์—˜๋ฆฌ๋จผํŠธ๊ฐ€ ๋…ธ์ถœ์ค‘์ธ์ง€ ํ™•์ธํ•˜๋ ค๋ฉด ์–ด๋–ป๊ฒŒ ํ•ด์•ผํ• ๊นŒ? ์ด...

    4๋ถ„
  • Typescript, React, NextJs, Koa, Styled Component ๋กœ ํ”„๋ก ํŠธ์—”๋“œ ํ™˜๊ฒฝ ๋งŒ๋“ค๊ธฐ

    ์ด ๋ฌธ์„œ๋Š” ๋” ์ด์ƒ ์—…๋ฐ์ดํŠธ ํ•˜์ง€ ์•Š์„ ์ƒ๊ฐ์ด๋‹ค. ๋Œ€์‹  https://github.com/yceffort/koa-nextjs-react-typescript-boilerplate ์—ฌ๊ธฐ์—์„œ ๊ณ„์† ํ•ด์„œ ๋งŒ๋“ค์–ด ๊ฐ€๊ณ  ์žˆ๋‹ค. ## ์‚ฌ์šฉํ•œ ์˜คํ”ˆ์†Œ์Šค ### React ์ž์„ธํ•œ ์„ค๋ช…์€ ์ƒ๋žต ํ•œ๋‹ค ### Nextjs [NextJs](https://nextjs.org...

    4๋ถ„
  • Typescript Type, Enum, Partial, Record๋กœ ๊ธ€๋กœ๋ฒŒ ๋ณ€์ˆ˜ ๊ด€๋ฆฌํ•˜๊ธฐ

    ## ๊ณ ๋ฏผ์ง€์  - Global ๋กœ ๊ด€๋ฆฌํ•˜๋Š” Colorset Red, Blue, Green, Black์ด ์žˆ๋‹ค. - ์ด ์ƒ‰๋“ค์€ ๊ฐ๊ฐ ์ง€์ •๋œ ์นผ๋ผ์ฝ”๋“œ๊ฐ€ ์žˆ๋‹ค - ๊ทธ๋Ÿฌ๋‚˜ ๋•Œ๋กœ๋Š” ๊ทธ ์ปฌ๋Ÿฌ์ฝ”๋“œ์— ๋งž๊ฒŒ ์•ˆ์“ฐ๋Š” ๊ฒฝ์šฐ๋„ ์žˆ๋‹ค - ๊ทธ๋Ÿฌ๋‚˜ ๋•Œ๋กœ๋Š” ์ € ๋„ค๊ฐœ๋ฅผ ๋‹ค ์•ˆ์“ฐ๊ณ  1~3๊ฐœ๋งŒ ์“ฐ๋Š” ๊ฒฝ์šฐ๊ฐ€ ์žˆ๋‹ค. ## Union types [Union Type](https://www....

    5๋ถ„
  • React ๊ณต๋ถ€ํ•˜๊ธฐ 7 - ์ปดํฌ๋„ŒํŠธ ๋ผ์ดํ”„ ์‚ฌ์ดํด

    ## React Component Life Cycle ๋ผ์ดํ”„ ์‚ฌ์ดํด์€ ์ด 10๊ฐ€์ง€๋‹ค. `Will`์ ‘๋‘์‚ฌ๋Š” ์–ด๋–ค ์ž‘์—…์„ ์ž‘๋™ํ•˜๊ธฐ์ „์— ์‹คํ–‰ํ•˜๋Š” ๋ฉ”์†Œ๋“œ๊ฐ€, `Did`๋Š” ์–ด๋–ค ์ž‘์—…์„ ํ•œ ํ›„์— ์‹คํ•ด์˜ค๋””๋Š” ๋ฉ”์„œ๋“œ๋‹ค. ์ด ๋ฉ”์„œ๋“œ๋“ค์€ ์ปดํฌ๋„ŒํŠธ ํด๋ž˜์Šค์—์„œ ๋ฎ์–ด์จ์„œ ์„ ์–ธํ•˜์—ฌ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค. ๋ผ์ดํ”„์‚ฌ์ดํด์€ ์ด 3๊ฐ€์ง€ ์นดํ…Œ๊ณ ๋ฆฌ๋กœ ๋‚˜๋ˆŒ ์ˆ˜ ์žˆ๋Š”๋ฐ, `mount`, `unm...

    5๋ถ„
  • React ๊ณต๋ถ€ํ•˜๊ธฐ 8 - ํ•จ์ˆ˜ํ˜• ์ปดํฌ๋„ŒํŠธ

    ### ํ•จ์ˆ˜ํ˜• ์ปดํฌ๋„ŒํŠธ ```javascript import React from 'react'; function Hello(props) { return ( <div>hello {props.name}</div> ) } ``` ํ•จ์ˆ˜ํ˜• ์ปดํฌ๋„ŒํŠธ๋Š” ์ปดํฌ๋„ŒํŠธ์—์„œ ๋ผ์ดํ”„์‚ฌ์ดํด, state ๋“ฑ์˜ ๊ธฐ๋Šฅ์„ ์ œ๊ฑฐํ•œ ์ƒํƒœ์ด๋ฏ€๋กœ ๋ฉ”๋ชจ๋ฆฌ ์‚ฌ์šฉ๋Ÿ‰์ด...

    1๋ถ„
  • Javascript - Promise

    ## Promise ```javascript new Promise(executor) ``` `executor`๋Š” `resolve`๋ฐ `reject` ์ธ์ˆ˜๋ฅผ ์ „๋‹ฌํ•  ์‹คํ–‰ํ•จ์ˆ˜๋ฅผ ์˜๋ฏธํ•œ๋‹ค. ์‹คํ–‰ํ•จ์ˆ˜๋Š” `resolve`์™€ `reject`๋ฅผ ๋ฐ›์•„ ์ฆ‰์‹œ ์‹คํ–‰๋œ๋‹ค. ์‹คํ–‰ํ•จ์ˆ˜๋Š” ๋ณดํ†ต ๋น„๋™๊ธฐ ์ž‘์—…์„ ์‹œ์ž‘ํ•œ ํ›„, ๋ชจ๋“  ์ž‘์—…์„ ๋๋‚ด๋ฉด `resolve`๋ฅผ ํ˜ธ์ถœํ•ด์„œ `Prom...

    2๋ถ„
  • Javascript - Destructuring Assignment

    ## ๊ตฌ์กฐ ๋ถ„ํ•ด ํ• ๋‹น ๊ตฌ์กฐ ๋ถ„ํ•ด ํ• ๋‹น์€ ๋ฐฐ์—ด์ด๋‚˜ ๊ฐ์ฒด์˜ ์†์„ฑ์„ ๋ง๊ทธ๋Œ€๋กœ ๋ถ„ํ•ดํ•˜์—ฌ, ๋ถ„ํ•ด ํ•œ ๊ฐ’์„ ๊ฐœ๋ณ„๋ณ€์ˆ˜์— ๋‹ด์„ ์ˆ˜ ์žˆ๊ฒŒ ๋„์™€์ฃผ๋Š” ํ‘œํ˜„์‹์ด๋‹ค. ```javascript let a, b, rest; [a, b] = [10, 20]; console.log(a); // 10 console.log(b); // 20 // rest ํŒจํ„ด์„ ์ด์šฉํ•˜์—ฌ ๋‚˜๋จธ์ง€๋ฅผ ๋ชจ๋‘...

    3๋ถ„
  • React ๊ณต๋ถ€ํ•˜๊ธฐ 5 - Reference

    ## Reference (Ref) ํŠน์ • DOM์š”์†Œ์— ์ž‘์—…์„ ํ•˜๊ธฐ ์œ„ํ•ด์„œ id๋ฅผ ๋ถ€์—ฌํ•˜๋Š” ๊ฒƒ ์ฒ˜๋Ÿผ, React์—์„œ DOM์— ์ด๋ฆ„์„ ๋‹ค๋Š” ๋ฐฉ์‹์ด ์žˆ๋Š”๋ฐ ์ด๊ฒƒ์ด ๋ฐ”๋กœ ref (Reference)๋‹ค. ๋ฐ˜๋“œ์‹œ, `DOM์— ์ง์ ‘์ ์œผ๋กœ ์ ‘๊ทผํ•˜์—ฌ ์กฐ์ž‘์ด ํ•„์š”ํ•  ๋•Œ ๋งŒ ์ด์šฉํ•ด์•ผ ํ•œ๋‹ค.` ### ์ปดํผ๋„ŒํŠธ ๋‚ด๋ถ€์—์„œ ์‚ฌ์šฉ ```javascript import React, ...

    2๋ถ„