๐Ÿฅ•
TIL
  • [TIL] Studying tech / computer science knowledge
  • KeyMap
  • ์•Œ๊ณ ๋ฆฌ์ฆ˜
    • ๋ณต์žก๋„ ๊ณ„์‚ฐ ( Computational Complexity )
    • DisjointSet-unionFind
    • Bellman-ford Algorithm
    • Dijkstra's Algorithm
    • DP ( Dynamic Programming , ๋™์  ๊ณ„ํš๋ฒ• )
    • ํ”Œ๋กœ์ด๋“œ-์›Œ์…œ ์•Œ๊ณ ๋ฆฌ์ฆ˜ (Floyd-Warshall algorithm)
    • Kruskal's Algorithm
    • ์ตœ์žฅ ์ฆ๊ฐ€ ์ˆ˜์—ด (Longes Increasing Subsequence)
    • Prim's Algorithm
    • ์ •๋ ฌ
    • ์‹œ๊ฐ„๋ณต์žก๋„ ์™€ ๊ณต๊ฐ„๋ณต์žก๋„ ( Time Complexity & Space Complexity )
    • Topological Sort (์œ„์ƒ ์ •๋ ฌ)
  • ์ฑ… ์ฝ๊ณ ๋‚œ ํ›„ ์š”์•ฝ
    • ํ”„๋กœ๊ทธ๋ž˜๋ฐ ๋Œ€ํšŒ์—์„œ ๋ฐฐ์šฐ๋Š” ์•Œ๊ณ ๋ฆฌ์ฆ˜ ๋ฌธ์ œํ•ด๊ฒฐ ์ „๋žต
    • cleancode
    • ๋„๋ฉ”์ธ ์ฃผ๋„ ์„ค๊ณ„๋กœ ์‹œ์ž‘ํ•˜๋Š” ๋งˆ์ดํฌ๋กœ์„œ๋น„์Šค ๊ฐœ๋ฐœ
    • ์˜ค๋ธŒ์ ํŠธ
  • CDC
    • debzium
    • kafka
  • ๊ฐœ๋ฐœ ์ƒ์‹
    • asciidoctor
    • ์ปดํŒŒ์ผ๋Ÿฌ
    • ELK ์Šคํƒ
    • ์—”๋””์•ˆ
    • git
    • Gitmoji
    • ํ…Œ์ŠคํŠธ ์ข…๋ฅ˜
    • ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ์™€ ํ”„๋ ˆ์ž„์›Œํฌ
    • ์ •๊ทœ ํ‘œํ˜„์‹
    • REST API
    • ๋™๊ธฐ์™€ ๋น„๋™๊ธฐ / Blocking๊ณผ NonBlocking
    • Transaction Script์™€ Domain Model
    • ๋””์ž์ธ ํŒจํ„ด
      • ํ–‰๋™ ํŒจํ„ด
      • ๊ฐ์ฒด ์ƒ์„ฑ ํŒจํ„ด
        • ์ถ”์ƒ ํŒฉํ† ๋ฆฌ ํŒจํ„ด
        • ๋นŒ๋” ํŒจํ„ด
        • ํŒฉํ† ๋ฆฌ ๋ฉ”์„œ๋“œ ํŒจํ„ด
        • [์ƒ์„ฑ ํŒจํ„ด] ํ”„๋กœํ†  ํƒ€์ž… (Prototype Parttern)
        • ์‹ฑ๊ธ€ํ†ค
      • ๊ตฌ์กฐ ํŒจํ„ด
        • ์–ด๋Œ‘ํ„ฐ ํŒจํ„ด
        • ๋ธŒ๋ฆฟ์ง€ ํŒจํ„ด
        • ์ปดํฌ์ง“(Composite) ํŒจํ„ด
        • ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ
        • ํ”„๋ก์‹œ
    • refactoring
      • ์ค‘๋ณต ์ฝ”๋“œ
      • ์ „์—ญ ๋ฐ์ดํ„ฐ
      • ๊ธด ํ•จ์ˆ˜
      • ๊ธด ๋งค๊ฐœ๋ณ€์ˆ˜ ๋ชฉ๋ก
      • ๊ฐ€๋ณ€ ๋ฐ์ดํ„ฐ
      • ์ดํ•ดํ•˜๊ธฐ ํž˜๋“  ์ด๋ฆ„
  • ์ž๋ฃŒ๊ตฌ์กฐ
    • AVL Tree
    • Splay Tree
    • aaTree
    • array-list
    • ์ž๋ฃŒ๊ตฌ์กฐ ์‹œ๊ฐ„/๊ณต๊ฐ„ ๋ณต์žก๋„
    • ๊ทธ๋ž˜ํ”„
    • ํž™
    • Red Black Tree
    • stack-queue
    • ํŠธ๋ฆฌ ( Tree )
  • DevOps
    • MSA
    • Kubernetes
      • AccessingAPI
      • controller
      • dashboard
      • kubernetes
      • object
      • pod
      • service
      • volume
  • Java
    • ์–ด๋…ธํ…Œ์ด์…˜
    • ์ œ์–ด๋ฌธ
    • ๋ฐ์ดํ„ฐ ํƒ€์ž…
    • Enum
    • jvm
    • ์—ฐ์‚ฐ์ž
    • thread
    • Java8
      • CompletableFuture
      • Date/Time
      • ์–ด๋…ธํ…Œ์ด์…˜๊ณผ ๋ฉ”ํƒ€์ŠคํŽ˜์ด์Šค
      • ์ธํ„ฐํŽ˜์ด์Šค
      • ๋žŒ๋‹ค์‹
      • Optional
      • ์ŠคํŠธ๋ฆผ
  • JavaScript
    • moduleProject
    • webpack-babel
    • ์ฝ”์–ด ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ
      • array
      • ํ•จ์ˆ˜ ๋ฐ”์ธ๋”ฉ
      • ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ์™€ ํฌ์›Œ๋”ฉ
      • Class
      • ๋น„๊ต ์—ฐ์‚ฐ์ž
      • Date ๋‚ด์žฅ ๊ฐ์ฒด
      • destructuring-assignment
      • function
      • ํ•จ์ˆ˜์˜ prototype ํ”„๋กœํผํ‹ฐ
      • ๊ฐ€๋น„์ง€ ์ปฌ๋ ‰์…˜ ( Garbage Collection )
      • JSON (JavaScript Object Notation)
      • map-set
      • ๋‚ด์žฅ ํ”„๋กœํ† ํƒ€์ž…
      • new์—ฐ์‚ฐ์ž์™€ ์ƒ์„ฑ์ž ํ•จ์ˆ˜
      • ๊ฐ์ฒด
      • Object.keys, values, entries
      • ์˜ต์…”๋„ ์ฒด์ด๋‹ '?.'
      • ํ”„๋กœํผํ‹ฐ ํ”Œ๋ž˜๊ทธ
      • ํ”„๋กœํผํ‹ฐ ์ข…๋ฅ˜
      • ํ”„๋กœํ†  ํƒ€์ž…
      • ํ˜ธ์ถœ ์Šค์ผ€์ค„๋ง ( scheduling a call )
      • scope
      • this
      • type-conversions
      • type
      • ํ•จ์ˆ˜์˜ ์ž๋ฃŒํ˜•
      • var_let_const
  • Linux
    • ๊ธฐ๋ณธ ๋ช…๋ น์–ด
    • ํŒŒ์ผ ์ข…๋ฅ˜
    • ๋ฆฌ๋ˆ…์Šค
  • ๋„คํŠธ์›Œํฌ
    • ์‘์šฉ ๊ณ„์ธต ( Application Layer )
    • ์˜ค๋ฅ˜ ๊ฒ€์ถœ๊ณผ ์˜ค๋ฅ˜ ์ •์ •
    • Http
    • Http Header
    • ์ปดํ“จํ„ฐ ๋„คํŠธ์›Œํฌ๋ž€
    • ๋„คํŠธ์›Œํฌ ๊ณ„์ธต
    • ๋„คํŠธ์›Œํฌ ์ œ์–ด ์˜์—ญ
    • ์ „์†ก ๊ณ„์ธต ( Transport Layer )
  • PHP
    • Facade
    • composer
    • scopeResolutionOperator
    • Laravel
      • SocialProvider
      • architecture
      • blade
      • controller
      • db
      • dbArchitecture
      • debug
      • eloquent
      • email
      • event
      • exceptionHandling
      • middleware
      • model
      • modelFactory
      • pagingLoading
      • queryBuilder
      • route
      • scout
      • seeding
      • tntsearch
      • validate
      • view
  • React
    • Next.js
    • React ๋ž€?
  • Spring
    • Controller
    • ์š”์ฒญ์ด ๋“ค์–ด์™”์„๋•Œ ์Šคํ”„๋ง์ด ์ฒ˜๋ฆฌํ•˜๋Š” ๋ฐฉ๋ฒ• ( ๋‚ด๋ถ€๊ตฌ์กฐ )
    • ConfigurationProperties
    • Entity / DTO / VO
    • Maven
    • Repository์™€ DAO
    • ์Šคํ”„๋ง ๋นˆ
    • Spring Framework
    • MVC ํŒจํ„ด
    • ๋„๋ฉ”์ธ ์ž…๋ ฅ๊ฐ’ ๊ฒ€์ฆ
    • Spring Cloud
      • Spring Cloud
      • Eureka
    • Spring Data
      • JPA
      • JPA ์–ด๋…ธํ…Œ์ด์…˜
      • ์—”ํ‹ฐํ‹ฐ ๋น„๊ต
      • ๋ณตํ•ฉ ํ‚ค์™€ ์‹๋ณ„ ๊ด€๊ณ„ ๋งคํ•‘
      • JPA ์˜ˆ์™ธ์ฒ˜๋ฆฌ
      • ๊ฐ์ฒด์ง€ํ–ฅ ์ฟผ๋ฆฌ
      • EntityManagerFactory์™€ EntityManager
      • JPA ์ตœ์ ํ™”
      • ํ”„๋ก์‹œ์™€ ์—ฐ๊ด€๊ด€๊ณ„ ๋งตํ•‘
      • ์—ฐ๊ด€๊ด€๊ณ„
      • ์ƒ์†๊ด€๊ณ„ ๋งตํ•‘
      • ํŠธ๋žœ์žญ์…˜ ๋ฒ”์œ„์™€ ์˜์†์„ฑ ์ปจํ…์ŠคํŠธ
      • ๋ฐ์ดํ„ฐ ํƒ€์ž…
      • MySQL ์—ฐ๊ฒฐ
      • Pageable
    • Spring Project๋“ค๊ณผ library
      • Custom Serialize
      • Elasticsearch Index API
      • Spring HATEOAS
      • lombok (๋กฌ๋ณต)
      • Model Mapper
      • Object Mapper
      • Representation Model
      • Spring REST Docs
      • Spring Boot
    • Spring Security
      • Spring Security
      • Authentication
      • Authentication Filter
      • Authorization Filter
      • Filter Chain
      • SecurityContext
      • Spring OAuth2.0
    • Spring Test
      • AssertJ
      • Junit5
      • JunitParams
      • Mock Object
  • DataBase
    • ALIAS
    • CONCAT
    • CTE
    • Group By
    • HAVING
    • IFNULL
    • ์ธ๋ฑ์Šค
    • JOIN
    • ORDER BY
    • ROLLUP
    • SELECT
    • SELECT DISTINCT
    • SQL
    • WHERE
  • Web ์ƒ์‹
    • OAuth
    • WAS
    • HTTPํ†ต์‹  ๊ธฐ๋ฐ˜ ์ธ์ฆ
    • ๋ธŒ๋ผ์šฐ์ €
    • CSR ๊ณผ SSR
    • HTTPS
    • Web
Powered by GitBook
On this page
  • ๋ฐฐ์—ด
  • ์„ ์–ธ๋ฐฉ๋ฒ•
  • ํŠน์ง•
  • ํ•จ์ˆ˜
  • ์š”์†Œ ์ถ”๊ฐ€ / ์ œ๊ฑฐ
  • ๋ฐฐ์—ด ๋ฐ˜๋ณต์ž‘์—…
  • ๋ฐฐ์—ด ํƒ์ƒ‰
  • ๋ฐฐ์—ด ๋ณ€ํ˜•
  • Array.from
  1. JavaScript
  2. ์ฝ”์–ด ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ

array

๋ฐฐ์—ด

์ˆœ์„œ๊ฐ€ ์žˆ๋Š” ์ปฌ๋ ‰์…˜์„ ์ €์žฅํ•˜๊ธฐ์œ„ํ•œ ์ž๋ฃŒ๊ตฌ์กฐ

ํŠน๋ณ„ํ•œ ๊ฐ์ฒด์ค‘ ํ•œ ์ข…๋ฅ˜์ด๊ธฐ ๋•Œ๋ฌธ์— length๋ผ๋Š” ํ”„๋กœํผํ‹ฐ์™€ ๋Œ€๊ด„ํ˜ธ ์ ‘๊ทผ๋“ฑ ์ด์šฉ์ด ๊ฐ€๋Šฅํ•˜๋‹ค.

์„ ์–ธ๋ฐฉ๋ฒ•

let arr = new Array();
let arr = [];

ํŠน์ง•

  • ๋ฐฐ์—ด ์š”์†Œ์˜ ์ž๋ฃŒํ˜•์— ์ œ์•ฝ์ด ์—†๋‹ค.

    let arr = [
      '์‚ฌ๊ณผ',
      { name: '์ด๋ณด๋ผ' },
      true,
      function () {
        alert('์•ˆ๋…•ํ•˜์„ธ์š”.');
      },
    ];
  • for...of๋ฌธ ์ด์šฉํ•ด์„œ ์ˆœํšŒ ๊ฐ€๋Šฅ

  • length ํ”„๋กœํผํ‹ฐ๋ฅผ ์ด์šฉํ•ด์„œ ๋ฐฐ์—ด์„ ์ž๋ฅด๋Š” ๊ฒŒ ๊ฐ€๋Šฅํ•˜๋‹ค.

    let arr = [1, 2, 3, 4, 5];
    arr.legth = 2;
    alert(arr); //1,2
  • ๋‚ด๋ถ€์ ์œผ๋กœ toString ๋ฉ”์„œ๋“œ๊ฐ€ ๊ตฌํ˜„๋˜์–ด ์žˆ์–ด ํ˜ธ์ถœ์‹œ ์‰ผํ‘œ๋ฅผ ๊ตฌ๋ถ„ํ•œ ๋ฌธ์ž์—ด์ด ๋ฐ˜ํ™˜๋œ๋‹ค.

    let arr = [1, 2, 3];
    
    alert(arr); //1,2,3
    alert(String(arr) === '1,2,3'); //true
  • ๋ฐฐ์—ด๋„ ๊ฐ์ฒด์ด๊ธฐ ๋•Œ๋ฌธ์— ์™„์ „ํ•œ ๋ณต์ œ๊ฐ€ ์•„๋‹Œ ์ฐธ์กฐ์— ์˜ํ•œ ๋ณต์‚ฌ๊ฐ€ ์ด๋ฃจ์–ด์ง„๋‹ค.

  • ๊ฐ์ฒดํ˜•์ด๊ธฐ ๋•Œ๋ฌธ์— typeof๋กœ๋Š” ์ผ๋ฐ˜ ๊ฐ์ฒด์™€ ๋ฐฐ์—ด์„ ๊ตฌ๋ถ„ํ•  ์ˆ˜ ์—†๋‹ค.

    Array.isArray()์ด์šฉ

    alert(typeof {}); // object
    alert(typeof []); // object
    alert(Array.isArray({})); // false
    alert(Array.isArray([])); // true
  • sort์ œ์™ธ ๋Œ€๋ถ€๋ถ„์˜ ํ•จ์ˆ˜๋ฅผ ํ˜ธ์ถœํ•˜๋Š” ๋ฉ”์„œ๋“œ์—์„œ thisArg๋ผ๋Š” ๋งค๊ฐœ๋ณ€์ˆ˜๋ฅผ ์˜ต์…˜์œผ๋กœ ๋ฐ›์„์ˆ˜ ์žˆ๋‹ค.

    let army = {
      minAge: 18,
      maxAge: 27,
      canJoin(user) {
        return user.age >= this.minAge && user.age < this.maxAge;
      },
    };
    
    let users = [{ age: 16 }, { age: 20 }, { age: 23 }, { age: 30 }];
    
    // army.canJoin ํ˜ธ์ถœ ์‹œ ์ฐธ์„ ๋ฐ˜ํ™˜ํ•ด์ฃผ๋Š” user๋ฅผ ์ฐพ์Œ
    let soldiers = users.filter(army.canJoin, army);
    
    alert(soldiers.length); // 2
    alert(soldiers[0].age); // 20
    alert(soldiers[1].age); // 23

    army๋ผ๋Š” thisArg๋งค๊ฐœ๋ณ€์ˆ˜๋ฅผ ํ•จ์ˆ˜์— ์ „๋‹ฌํ•˜๊ณ  ์žˆ์–ด thisArg๋Š” ํ•จ์ˆ˜์˜ this๊ฐ€ ๋œ๋‹ค.

ํ•จ์ˆ˜

์š”์†Œ ์ถ”๊ฐ€ / ์ œ๊ฑฐ

  • push() : ๋งจ๋์— ์š”์†Œ๋ฅผ ์ถ”๊ฐ€

  • pop() : ๋งจ๋์˜ ์š”์†Œ๋ฅผ ์ถ”์ถœ

    ์Šคํƒ์„ ์‰ฝ๊ฒŒ ๊ตฌํ˜„ ๊ฐ€๋Šฅ

  • shift() : ์ œ์ผ ์•ž ์š”์†Œ๋ฅผ ๊บผ๋‚ด ์ œ๊ฑฐํ•œ ํ›„ ๋‚จ์•„์žˆ๋Š” ์š”์†Œ๋“ค์„ ์•ž์œผ๋กœ ๋ฐ€์–ด์ฃผ๋Š” ํ•จ์ˆ˜

    ์ด๋ฅผ ์ด์šฉํ•ด ํ๋ฅผ ์‰ฝ๊ฒŒ ๊ตฌํ˜„๊ฐ€๋Šฅํ•˜๋‹ค.

  • unshift() : ๋ฐฐ์—ด ์•ž์— ์š”์†Œ๋ฅผ ์ถ”๊ฐ€

  • splice() : ๋ฐฐ์—ด์—์„œ ์š”์†Œ๋ฅผ ์ง€์šฐ๊ณ  ์‚ฝ์ž…

    • arr.splice(start, length, element1 ...)

    • ์Œ์ˆ˜ ์ธ๋ฑ์Šค๋„ ์‚ฌ์šฉ์ด ๊ฐ€๋Šฅํ•˜๋‹ค.

    let arr = ['I', 'study', 'JavaScript', 'right', 'now'];
    
    arr.splice(0, 3, "Let's", 'dance');
    
    alert(arr); // now ["Let's", "dance", "right", "now"]
  • slice(start,end) : ์š”์†Œ ์ง€์šฐ๊ธฐ

    start๋ถ€ํ„ฐ end๊นŒ์ง€ ์š”์†Œ๋ฅผ ๋ณต์‚ฌํ•œ ์ƒˆ๋กœ์šด ๋ฐฐ์—ด์„ ๋ฐ˜ํ™˜

  • concat(arg1,arg2,...) : ๊ธฐ์กด ๋ฐฐ์—ด์˜ ์š”์†Œ๋ฅผ ์‚ฌ์šฉํ•ด ์ƒˆ๋กœ์šด ๋ฐฐ์—ด์„ ๋งŒ๋“ค๊ฑฐ๋‚˜ ๊ธฐ์กด ๋ฐฐ์—ด์— ์š”์†Œ๋ฅผ ์ถ”๊ฐ€ํ•˜๊ธฐ

    let arr = [1, 2];
    
    alert(arr.concat([3, 4])); // 1,2,3,4
    alert(arr.concat([3, 4], [5, 6])); // 1,2,3,4,5,6
    alert(arr.concat([3, 4], 5, 6)); // 1,2,3,4,5,6
    • ์ธ์ž๋กœ ๊ฐ์ฒด๊ฐ€ ๋„˜์–ด์˜ค๋ฉด ๊ฐ์ฒด๋Š” ๋ถ„ํ•ด๋˜์ง€ ์•Š๊ณ  ํ†ต์œผ๋กœ ๋ณต์‚ฌ๋˜์–ด ๋”ํ•ด์ง„๋‹ค.

      let arr = [1, 2];
      
      let arrayLike = {
        0: 'something',
        length: 1,
      };
      
      alert(arr.concat(arrayLike)); // 1,2,[object Object]

      Symbol.isConcatSpreadable์ด ์žˆ์œผ๋ฉด concat์€ ๊ฐ์ฒด๋ฅผ ๋ฐฐ์—ด ์ทจ๊ธ‰

      let arr = [1, 2];
      
      let arrayLike = {
        0: 'something',
        1: 'else',
        [Symbol.isConcatSpreadable]: true,
        length: 2,
      };
      
      alert(arr.concat(arrayLike)); // 1,2,something,else

๋ฐฐ์—ด ๋ฐ˜๋ณต์ž‘์—…

  • forEach() : ๋ฐ˜๋ณต์ž‘์—… ํ•˜๊ธฐ

    /*๊ธฐ๋ณธ ๊ตฌ๋ฌธ*/
    arr.forEach(function (item, index, array) {});
    
    let arr = ['Bilbo', 'Gandalf', 'Nazgul'];
    arr.forEach((item, index, array) => {
      alert(`${item} is at index ${index} in ${array}`);
    });

๋ฐฐ์—ด ํƒ์ƒ‰

  • indexOf(item,from), lastIndexOf(item,from), includes(item,from) : ๋ฌธ์ž์—ด๊ณผ ๋™์ผํ•˜๊ฒŒ item์ด from๋ถ€ํ„ฐ ์žˆ๋Š”์ง€ ๊ฒ€์‚ฌํ•˜๋Š” ํ•จ์ˆ˜

    • ๋‚ด๋ถ€์ ์œผ๋กœ ์š”์†Œ๋ฅผ ์ฐพ์„๋•Œ ===์„ ์‚ฌ์šฉํ•œ๋‹ค.

    • includes๋Š” NaN๋„ ์ฒ˜๋ฆฌ

      const arr = [NaN];
      alert(arr.indexOf(NaN)); // -1 (=== ๋Š” NaN์—” ๋™์ž‘ํ•˜์ง€ ์•Š์œผ๋ฏ€๋กœ 0์ด ์ถœ๋ ฅ๋˜์ง€ ์•Š์Šต๋‹ˆ๋‹ค.)
      alert(arr.includes(NaN)); // true
  • find(function) : ๊ฐ์ฒด๋กœ ์ด๋ฃจ์–ด์ง„ ๋ฐฐ์—ด์ด ์žˆ์„๋•Œ ํŠน์ • ์กฐ๊ฑด์— ๋ถ€ํ•ฉํ•˜๋Š” ๊ฐ์ฒด๋ฅผ ๋ฐฐ์—ด๋‚ด์—์„œ ์ฐพ์„ ๋•Œ ์ด์šฉ

    • ์กฐ๊ฑด์— ๋ถ€ํ•ฉํ•˜๋Š”(true๊ฐ€ ๋˜๋Š”) ํ•˜๋‚˜์˜ ์š”์†Œ๋งŒ ์ฐพ๋Š”๋‹ค

    /*๊ธฐ๋ณธ ๊ตฌ๋ฌธ*/
    let result = arr.find(function (item, index, array) {
      // true๊ฐ€ ๋ฐ˜ํ™˜๋˜๋ฉด ๋ฐ˜๋ณต์ด ๋ฉˆ์ถ”๊ณ  ํ•ด๋‹น ์š”์†Œ๋ฅผ ๋ฐ˜ํ™˜
      // ์กฐ๊ฑด์— ํ•ด๋‹นํ•˜๋Š” ์š”์†Œ๊ฐ€ ์—†์œผ๋ฉด undefined๋ฅผ ๋ฐ˜ํ™˜
    });
    • function์œผ๋กœ ํ™”์‚ด ํ•จ์ˆ˜๋ฅผ ์ด์šฉ๊ฐ€๋Šฅํ•˜๋‹ค.

      let users = [
        { id: 1, name: 'John' },
        { id: 2, name: 'Pete' },
        { id: 3, name: 'Mary' },
      ];
      
      let user = users.find((item) => item.id == 1);
      
      alert(user.name); // John
  • filter(function) : ์กฐ๊ฑด์ด ์ถฉ์กฑ ๋˜๋Š” ๋ชจ๋“  ์š”์†Œ๋ฅผ ๋‹ด์€ ๋ฐฐ์—ด์„ ๋ฐ˜ํ™˜

    /*๊ธฐ๋ณธ ๊ตฌ๋ฌธ*/
    let results = arr.filter(function (item, index, array) {
      // ์กฐ๊ฑด์„ ์ถฉ์กฑํ•˜๋Š” ์š”์†Œ๋Š” results์— ์ˆœ์ฐจ์ ์œผ๋กœ ๋”ํ•ด์ง‘๋‹ˆ๋‹ค.
      // ์กฐ๊ฑด์„ ์ถฉ์กฑํ•˜๋Š” ์š”์†Œ๊ฐ€ ํ•˜๋‚˜๋„ ์—†์œผ๋ฉด ๋นˆ ๋ฐฐ์—ด์ด ๋ฐ˜ํ™˜๋ฉ๋‹ˆ๋‹ค.
    });
    • find()์™€ ๋งˆ์ฐฌ๊ฐ€์ง€๋กœ function์œผ๋กœ ํ™”์‚ด ํ•จ์ˆ˜๋ฅผ ์ด์šฉ๊ฐ€๋Šฅํ•˜๋‹ค.

      let users = [
        { id: 1, name: 'John' },
        { id: 2, name: 'Pete' },
        { id: 3, name: 'Mary' },
      ];
      
      // ์•ž์ชฝ ์‚ฌ์šฉ์ž ๋‘ ๋ช…์„ ๋ฐ˜ํ™˜ํ•ฉ๋‹ˆ๋‹ค.
      let someUsers = users.filter((item) => item.id < 3);
      
      alert(someUsers.length); // 2

๋ฐฐ์—ด ๋ณ€ํ˜•

  • map(function) : ๋ฐฐ์—ด ์š”์†Œ ์ „์ฒด๋ฅผ ๋Œ€์ƒ์œผ๋กœ ํ•จ์ˆ˜๋ฅผ ํ˜ธ์ถœํ•˜๊ณ  ๊ฒฐ๊ณผ๋ฅผ ๋ฐฐ์—ด๋กœ ๋ฐ˜ํ™˜

    let result = arr.map(function (item, index, array) {});
    
    let lengths = ['Bilbo', 'Gandalf', 'Nazgul'].map((item) => item.length);
    alert(lengths); // 5,7,6
  • sort(function) : ๋ฐฐ์—ด์„ ์ •๋ ฌ

    ๊ธฐ๋ณธ์ ์œผ๋กœ ๋ฐฐ์—ด์˜ ๋‚ด๋ถ€ ์š”์†Œ๋ฅผ ๋ฌธ์ž์—ด๋กœ ์ทจ๊ธ‰ํ•˜์—ฌ ์žฌ์ •๋ ฌํ•œ๋‹ค.

    let arr = [1, 2, 15];
    arr.sort();
    alert(arr); // 1, 15, 2

    ๋”ฐ๋ผ์„œ ์ˆซ์ž๋กœ ๋น„๊ตํ•˜๋ ค๋ฉด ๋‚ด๋ถ€์— ํ•จ์ˆ˜๋ฅผ ์ถ”๊ฐ€ํ•ด์ฃผ๋ฉด ๋œ๋‹ค.

    let arr = [1, 2, 15];
    arr.sort((a, b) => a - b);
    alert(arr); // 1, 2, 15

    ๋น„๊ต ํ•จ์ˆ˜๊ฐ€ ์–‘์ˆ˜๋ฅผ ๋ฐ˜ํ™˜ํ•˜๋Š” ๊ฒฝ์šฐ๋Š” ์ฒซ๋ฒˆ์งธ ์ธ์ˆ˜๊ฐ€ ๋‘๋ฒˆ์งธ๋ณด๋‹ค ํฌ๋‹ค์ด๊ณ  ์Œ์ˆ˜๋Š” ์ž‘๋‹ค์ด๋‹ค.

    ๋ฌธ์ž์—ด์€ ์œ ๋‹ˆ์ฝ”๋“œ ๊ธฐ์ค€์œผ๋กœ ์ •๋ ฌํ•˜๊ธฐ ๋•Œ๋ฌธ์— ๋ฐœ์Œ๊ธฐํ˜ธ๋“ฑ ์ •ํ™•ํ•˜์ง€ ์•Š์„ ์ˆ˜ ์žˆ์–ด str.localeCompare(str2)๋ฅผ ์ด์šฉํ•˜๋ฉด ์ •ํ™•ํ•˜๊ฒŒ ๋น„๊ต๊ฐ€ ๊ฐ€๋Šฅํ•˜๋‹ค.

  • reverse() : ๋ฐฐ์—ด์„ ์—ญ์ˆœ์œผ๋กœ ์ •๋ ฌ

  • split(delim) : ๊ตฌ๋ถ„์ž(delim)์„ ๊ธฐ์ค€์œผ๋กœ ๋ฌธ์ž์—ด์„ ์ชผ๊ฐœ์ค€๋‹ค.

    let arr = 'Bilbo, Gandalf, Nazgul, Saruman'.split(', ');
    alert(arr); // Bilbo, Gandalf,Nazgul, Saruman
    
    let arr2 = 'Bilbo, Gandalf, Nazgul, Saruman'.split(', ', 2);
    alert(arr2); // Bilbo, Gandalf
    • delim์œผ๋กœ ๋นˆ๋ฌธ์ž์—ด ('')์„ ์ฃผ๋ฉด ๊ธ€์ž ๋‹จ์œ„๋กœ ๋ถ„๋ฆฌํ•  ์ˆ˜ ์žˆ๋‹ค.

  • join(glue) : split๊ณผ ๋ฐ˜๋Œ€์˜ ๊ธฐ๋Šฅ์œผ๋กœ ์ธ์ˆ˜๋ฅผ ์‚ฌ์šฉํ•ด ๋ฐฐ์—ด ์š”์†Œ๋ฅผ ๋ชจ๋‘ํ•ฉ์นœ ๋ฌธ์ž์—ด์„ ๋งŒ๋“ค์–ด์ค€๋‹ค.

    let arr = ['Bilbo', 'Gandalf', 'Nazgul'];
    let str = arr.join(';');
    alert(str); // Bilbo;Gandalf;Nazgul
  • reduce() : ๋ฐฐ์—ด์„ ๊ธฐ๋ฐ˜์œผ๋กœ ๊ฐ’ ํ•˜๋‚˜๋ฅผ ๋„์ถœํ•ด ๋‚ผ๋•Œ ์‚ฌ์šฉ

    /*๊ธฐ๋ณธ ๊ตฌ๋ฌธ*/
    let value = arr.reduce(
      function (accumulator, item, index, array) {
        // ...
      },
      [initial]
    );
    let arr = [1, 2, 3, 4, 5];
    
    let result = arr.reduce((sum, current) => sum + current, 0);
    
    alert(result); // 15

Array.from

์ดํ„ฐ๋Ÿฌ๋ธ”์ด๋‚˜ ์œ ์‚ฌ ๋ฐฐ์—ด์„ ๋ฐ›์•„ ์ง„์งœ Array๋ฅผ ์ƒ์„ฑํ•ด์ฃผ๋Š” ํ•จ์ˆ˜

๊ฐ์ฒด๋‚˜ ๋ฌธ์ž์—ด์€ ๋Œ€ํ‘œ์ ์ธ ๋‚ด์žฅ ์ดํ„ฐ๋Ÿฌ๋ธ”

  • ์ดํ„ฐ๋Ÿฌ๋ธ”(iterable) : Symbol.iterator๊ฐ€ ๊ตฌํ˜„๋œ ๊ฐ์ฒด

  • ์œ ์‚ฌ ๋ฐฐ์—ด(array-like) : ์ธ๋ฑ์Šค์™€ length ํ”„๋กœํผํ‹ฐ๊ฐ€ ์žˆ์–ด์„œ ๋ฐฐ์—ด์ฒ˜๋Ÿผ ๋ณด์ด๋Š” ๊ฐ์ฒด

let arrayLike = {
  0: 'Hello',
  1: 'World',
  length: 2,
};

let arr = Array.from(arrayLike);
alert(arr.pop()); // World

์ด๋ฅผ ์ด์šฉํ•ด ๋ฐฐ์—ด์„ ์ดˆ๊ธฐํ™”๋„ ํ•ด์ค„์ˆ˜ ์žˆ๋‹ค.

let arr = Array.from({ length: 5 }, () => 0);

์ด๋Š” ์•„๋ž˜์™€ ๊ฐ™์€ ๊ธฐ๋Šฅ์„ ํ•œ๋‹ค.

let arr = [];
arr.fill(0, 0, 5);
Previous์ฝ”์–ด ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธNextํ•จ์ˆ˜ ๋ฐ”์ธ๋”ฉ

Last updated 3 years ago