66651
๐Ÿ‘€
66651
  • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (57)
    • note (28)
    • log (13)
    • error (9)
    • etc (7)

๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

  • ํ™ˆ
  • ํƒœ๊ทธ
  • ๋ฐฉ๋ช…๋ก

ํ‹ฐ์Šคํ† ๋ฆฌ

hELLO ยท Designed By ์ •์ƒ์šฐ.
66651

๐Ÿ‘€

note

[JavaScript] ์‰ผํ‘œ ์—ฐ์‚ฐ์ž (Comma Operator)

์‰ผํ‘œ ์—ฐ์‚ฐ์ž๋ž€

MDN์—์„œ๋Š” ๋‹ค์Œ๊ณผ ๊ฐ™์ด ์ •์˜ํ•œ๋‹ค.


์‰ผํ‘œ ์—ฐ์‚ฐ์ž
๋Š” ๊ฐ ํ”ผ์—ฐ์‚ฐ์ž๋ฅผ ์™ผ์ชฝ์—์„œ ์˜ค๋ฅธ์ชฝ์œผ๋กœ ํ‰๊ฐ€ํ•˜๊ณ  ๋งˆ์ง€๋ง‰ ํ”ผ์—ฐ์‚ฐ์ž์˜ ๊ฐ’์„ ๋ฐ˜ํ™˜ํ•œ๋‹ค.

์‰ผํ‘œ ์—ฐ์‚ฐ์ž๋Š” ์ฃผ๋กœ ์—ฌ๋Ÿฌ ๋™์ž‘์„ ํ•˜๋‚˜์˜ ์ค„์—์„œ ์ฒ˜๋ฆฌํ•˜๋ ค๋Š” ๋ณต์žกํ•œ ๊ตฌ์กฐ์—์„œ ํ™œ์šฉํ•  ์ˆ˜ ์žˆ๋‹ค.

์—ฐ์‚ฐ์ž ์šฐ์„ ์ˆœ์œ„์—์„œ ๊ฐ€์žฅ ๋‚ฎ์€ ์ˆœ์œ„๋ฅผ ๊ฐ€์ง€๊ธฐ๋•Œ๋ฌธ์— ๋จผ์ € ์ˆ˜ํ–‰ํ•˜๊ธฐ ์œ„ํ•ด์„œ๋Š” ๊ด„ํ˜ธ๋ฅผ ์‚ฌ์šฉํ•ด์•ผ ํ•œ๋‹ค.

let x, y, z;
x = 1, y = 2, z = 3; // 3
console.log(x); // 1


let a, b, c;

a = (b = 5, c = 6); // 6
console.log(a); // 6

 

 

์‰ผํ‘œ ์—ฐ์‚ฐ์ž์˜ ํ™œ์šฉ

for ๋ฌธ

const array = [
    ['a', 'b', 'c'],
    ['d', 'e', 'f'],
    ['g', 'h', 'i'],
];

for (let i = 0, j = 2; i <= 2; i++, j--) {
    console.log(`array[${i}][${j}] = ${array[i][j]}`);
}

์œ„ ์˜ˆ์ œ๋Š” 2์ฐจ์› ๋ฐฐ์—ด์˜ ๋Œ€๊ฐ์„ ์— ์œ„์น˜ํ•˜๋Š” ์š”์†Œ์˜ ๊ฐ’์„ ์ถœ๋ ฅํ•˜๋Š” ์ฝ”๋“œ๋‹ค.

์‰ผํ‘œ ์—ฐ์‚ฐ์ž๋ฅผ ์‚ฌ์šฉํ•ด์„œ ํ•œ ์ค„์—์„œ ๋‘ ๊ฐœ์˜ ์—ฐ์‚ฐ์ด ์‹คํ–‰๋˜๊ณ  ์žˆ๋‹ค.  (i๋Š” ์ฆ๊ฐ€, j๋Š” ๊ฐ์†Œ)

 

reduce() ๋ฉ”์„œ๋“œ

const array = ['apple', 'banana', 'banana', 'orange', 'orange', 'orange'];
const group = array.reduce((acc, cur) => ((acc[cur] = (acc[cur] || 0) + 1), acc), {});

console.log(group); // {apple: 1, banana: 2, orange: 3}

์œ„ ์˜ˆ์ œ๋Š” [ic]array[/ic]๋ฐฐ์—ด ๋‚ด ๊ฐ ๊ฐ’๊ณผ ๋นˆ๋„๋ฅผ ํฌํ•จํ•˜๋Š” [ic]group[/ic]๊ฐ์ฒด๋ฅผ ๋งŒ๋“œ๋Š” ์ฝ”๋“œ๋‹ค.

์‰ผํ‘œ ์—ฐ์‚ฐ์ž๋ฅผ ์‚ฌ์šฉํ•ด์„œ [ic]reduce()[/ic] ๋ฉ”์„œ๋“œ๊ฐ€ ์‹คํ–‰๋  ๋•Œ๋งˆ๋‹ค ๋นˆ๋„์ˆ˜๋ฅผ ์นด์šดํŒ… ํ•œ ๊ฐ’์„ ๋‹ด์€ ๊ฐ์ฒด [ic]acc[/ic]๋ฅผ ๋ˆ„์ ํ•˜๊ณ  ์žˆ๋‹ค.

 

 

์ •๋ฆฌ

  • ์‰ผํ‘œ ์—ฐ์‚ฐ์ž๋Š” ๊ฐ ํ”ผ์—ฐ์‚ฐ์ž๋ฅผ ์™ผ์ชฝ์—์„œ ์˜ค๋ฅธ์ชฝ์œผ๋กœ ํ‰๊ฐ€ํ•˜๊ณ  ๋งˆ์ง€๋ง‰ ํ”ผ์—ฐ์‚ฐ์ž์˜ ๊ฐ’์„ ๋ฐ˜ํ™˜ํ•œ๋‹ค.
  • ์ฝ”๋“œ๋ฅผ ์ค„์ด๋Š”๋ฐ์— ๋„์›€์ด ๋˜์ง€๋งŒ ๊ฐ€๋…์„ฑ์„ ์œ„ํ•ด ์ƒํ™ฉ์— ๋งž๊ฒŒ ์ž˜ ์‚ฌ์šฉํ•ด์•ผ ํ•  ๊ฒƒ ๊ฐ™๋‹ค๋Š” ์ƒ๊ฐ์ด ๋“ ๋‹ค.

 

 

์ฐธ๊ณ 

https://ko.javascript.info/operators

 

๊ธฐ๋ณธ ์—ฐ์‚ฐ์ž์™€ ์ˆ˜ํ•™

 

ko.javascript.info

https://dongmin-jang.medium.com/javascript-15%EA%B0%80%EC%A7%80-%EC%9C%A0%EC%9A%A9%ED%95%9C-map-reduce-filter-bfbc74f0debd

 

[Javascript] 15๊ฐ€์ง€ ์œ ์šฉํ•œ map, reduce, filter

์•„๋ž˜ ๊ธ€์„ ๋ฒˆ์—ญ ๋ฐ ์š”์•ฝํ•œ ๊ธ€.

dongmin-jang.medium.com

https://ko.javascript.info/operators

 

๊ธฐ๋ณธ ์—ฐ์‚ฐ์ž์™€ ์ˆ˜ํ•™

 

ko.javascript.info

 

 

์ €์ž‘์žํ‘œ์‹œ (์ƒˆ์ฐฝ์—ด๋ฆผ)
    'note' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • [Deep Dive] 22์žฅ this
    • [Deep Dive] 16์žฅ ํ”„๋กœํผํ‹ฐ ์–ดํŠธ๋ฆฌ๋ทฐํŠธ
    • [Deep Dive] 14-15์žฅ
    • [Deep Dive] 12-13์žฅ
    66651
    66651
    always awake

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”