1 ๋ถ„ ์†Œ์š”

For๋ฌธ๐Ÿ

(for), (for in), (for of), (forEach) ๋ฅผ ๋ฐฐ์›Œ๋ณด์ž


๋ฐ˜๋ณต๋ฌธ์˜ ํ•„์š”์ด์œ ์™€ ์‚ฌ์šฉ๋ฐฉ๋ฒ•
  1. ์ฝ”๋“œ๊ฐ€ ๊ธธ์–ด์ง์„ ๋ฐฉ์ง€
  2. ์ค‘๋ณต๋œ ์ฝ”๋“œ์˜ ์˜ค๋ฅ˜
  3. ์ค‘๋ณต์€ ์ค‘๋ณต์„ ๊ฐ•์š”
function getAllLetters(str) {

  let strArray = [];

  for(let i=0; i<str.length;i++) {

    strArray[i] = str.substr(i,1)

  }

  return strArray;

}

console.log(getAllLetters(flower));
//['f','l','o','w','e','r']

for๋ฌธ ๊ธฐ์ดˆ - ๋ฌธ์ž๋ฅผ ์ชผ๊ฐœ์–ด ๊ฐ ์ธ๋ฑ์Šค์— ๋„ฃ์–ด๋ณด๊ธฐ

const helloBot = people => {
  let greetings = ['์•ˆ๋…•ํ•˜์„ธ์š”','๋˜ ๋งŒ๋‚˜๋„ค์š”'];
  let result = [];
  for(let i = 0; i<people.length; i++) {
    if(people[i]===0) {
      result.push(greetings[0])
    } else result.push(greetings[1])
  }
  return result
}

0,1๋กœ ์ด๋ฃจ์–ด์ง„ ๋ฐฐ์—ด์„ helloBotํ•จ์ˆ˜์— ์ธ์ž๋กœ ๋„ฃ์–ด์ฃผ๋ฉด ๊ทธ์— ๋งž๋Š” ์ธ์‚ฌ๋ง์ด ๋‚˜์˜ด



For in๋ฌธ

for (๋ณ€์ˆ˜ in ๊ฐ์ฒด์‹) {
    // ๋ฌธ์žฅ
}

for in ๋ฌธ์˜ ๊ธฐ๋ณธ ๋ฌธ๋ฒ•

const Object= {
    name: 'LJH',
    age: 28,
}

for( let key in object) {
    console.log(key + ' : ' + object[key]);
}

// name : LJH
// age	: 28

๊ฐ์ฒด์˜ ํ”„๋กœํผํ‹ฐ๋ช…๊ณผ ํ”„๋กœํผํ‹ฐ๊ฐ’์„ ์—ด๊ฑฐํ•จ

์ฃผ์˜์‚ฌํ•ญ

  1. for in ๋ฌธ๋ฒ•์€ ์ˆœ์„œ๋ฅผ ๋ณด์žฅํ•˜์ง€์•Š์Œ. ์œ„์˜ ์ฝ”๋“œ๋Š” ๊ฒฐ๊ณผ๊ฐ€ ์ˆœ์„œ์— ๋งž๊ฒŒ ๋‚˜์™”์œผ๋‚˜ ๊ทธ๋Ÿฌ์ง€ ์•Š์„๋•Œ๋„ ์žˆ์Œ, ๊ทธ๋Ÿฌ๋ฏ€๋กœ ๋ฐฐ์—ด๊ณผ ๊ฐ™์€ ์ˆœ์„œ๋ฅผ ์˜์‹ํ•œ ๋ฐ์ดํ„ฐ ํƒ€์ž…์€ for in๋ฌธ ์‚ฌ์šฉ์„ ์ง€์–‘ํ•จ
  2. ๋‚˜์—ดํ•  ์ˆ˜ ์—†๋Š” ๊ฒƒ๋„ ์žˆ์Œ( ์ถ”ํ›„ ์‚ดํŽด๋ณผ์˜ˆ์ •)
  3. ํ”„๋กœํ† ํƒ€์ž…์—์„œ ์ƒ์†ํ•œ ํ”„๋กœํผํ‹ฐ๋„ ๋‚˜์—ด๋จ




For of๋ฌธ

for โ€ฆ of ๋ฌธ์€ ๋ฐ˜๋ณต๊ฐ€๋Šฅํ•œ ๊ฐ์ฒด(Array, Map, Set, String, TypeArray, arguments ๊ฐ์ฒด๋“ฑ)๋ฅผ ๋ฐ˜๋ณตํ•˜๋Š” ๋ฌธ๋ฒ•

for (๋ณ€์ˆ˜ of ๊ฐ์ฒด์‹) { // ๋ฌธ์žฅ }

for of ๋ฌธ์˜ ๊ธฐ๋ณธ ๋ฌธ๋ฒ•

const Object = [1, 2, 3, 4, [5, 6, 7]];

for (let key of Object) {
  console.log(key);
}

// 1, 2, 3, 4, [5, 6, 7]

๋ฐฐ์—ด์˜ ์š”์†Œ๋“ค๋งŒ ์—ด๊ฑฐํ•จ

let arr = new Set([1, 1, 2, 2, 3, 3]);

for (let key of arr) {
  console.log(key);
}

// 1,2,3

set๊ณผ for of๋ฌธ์„ ํ™œ์šฉํ•˜์—ฌ ์ค‘๋ณต๊ฐ’ ์ œ๊ฑฐ ํ›„ ์—ด๊ฑฐ



forEach๋ฌธ

arr.forEach(callback(item, index, array))

๊ธฐ๋ณธ๋ฌธ๋ฒ•

const arr = [1,2,3,4,5];

arr.forEach( (ele,index) => {
    console.log(ele, index);
})

//1 0
//2 1
//3 2
//4 3
//5 4

๊ธฐ๋ณธ ์‚ฌ์šฉ์˜ˆ์‹œ

const arr = [
  [1, 2, 3],
  [4, 5, 6],
  [7, 8, 9],
];

arr.forEach((ele) => {
  ele.forEach((ele) => console.log(ele));
});

// 1 2 3 4 5 6 7 8 9

2์ฐจ์›๋ฐฐ์—ด ์‚ฌ์šฉ์˜ˆ์‹œ

forEach๋ฌธ์€ ๋ฐฐ์—ด์—์„œ๋งŒ ์‚ฌ์šฉํ•˜๋Š” ๋ฉ”์„œ๋“œ์ด๋‹ค. ๋ฐฐ์—ด์—์„œ๋Š” for in๋ณด๋‹ค foreach๋ฌธ์„ ์‚ฌ์šฉํ•˜๋„๋ก ์ง€ํ–ฅํ•˜์ž.

์—…๋ฐ์ดํŠธ: