๐Ÿ“– [JavaScript] Array Method(1)

ํ˜ฑยท2022๋…„ 9์›” 9์ผ

JavaScript_Intermediate

๋ชฉ๋ก ๋ณด๊ธฐ
7/19

๐Ÿ“Œ arr.splice(n,m) : ํŠน์ • ์š”์†Œ ์ง€์›€

n๋ฒˆ์งธ ์š”์†Œ๋ถ€ํ„ฐ m๊ฐœ๋ฅผ ์ง€์šฐ๋Š” ๊ฒƒ

โœ”๏ธ arr.splice( n, m, x, y~): ํŠน์ • ์š”์†Œ ์ง€์šฐ๊ณ  ์ถ”๊ฐ€

n๋ฒˆ์งธ ์š”์†Œ๋ถ€ํ„ฐ m๊ฐœ๋ฅผ ์ง€์šฐ๊ณ  ๊ทธ ์ž๋ฆฌ๋ถ€ํ„ฐ x,y..~ ์š”์†Œ ์ฐจ๋ก€๋กœ ์ถ”๊ฐ€

let arr = [1,2,3,4,5]
arr.splice(1,3,100,200,);
console.log(arr); //[1,100,200,5]

let arr = ["๋‚˜๋Š”", "์ฒ ์ˆ˜", "์ž…๋‹ˆ๋‹ค."]
arr.splice(1,0, "๋Œ€ํ•œ๋ฏผ๊ตญ", "์†Œ๋ฐฉ๊ด€"] 
//์ด๋•Œ 0์€ ์•„๋ฌด๊ฒƒ๋„ ์ง€์šฐ์ง€ ์•Š๋Š” ๊ฒƒ์ด๋ฏ€๋กœ, index 1 ์ „์— ์ถ”๊ฐ€ํ•˜๊ฒŒ ๋จ.
//๋ณธ๋ž˜ 1๋ถ€ํ„ฐ ์‹œ์ž‘์ด๋ฏ€๋กœ.
console.log(arr); // ["๋‚˜๋Š”", "๋Œ€ํ•œ๋ฏผ๊ตญ", "์†Œ๋ฐฉ๊ด€", "์ฒ ์ˆ˜", "์ž…๋‹ˆ๋‹ค."]

โœ”๏ธ arr.splice(): ์‚ญ์ œ๋œ ์š”์†Œ ๋ฐ˜ํ™˜

let arr = [1,2,3,4,5]
let result = arr.splice(1,2);
console.log(arr); //[1,4,5]
console.log(arr); //[2, 3]

๐Ÿ“Œ arr.slice(n,m): n๋ถ€ํ„ฐ m๊นŒ์ง€ ๋ฐ˜ํ™˜

m์€ ํฌํ•จํ•˜์ง€ ์•Š๊ณ  ๋ฐ”๋กœ ์•ž์ž๋ฆฌ(index)์ด๋ฏ€๋กœ ์˜๋ฏธ
m์„ ์“ฐ์ง€ ์•Š์œผ๋ฉด ๋๊นŒ์ง€๋ผ๋Š” ์˜๋ฏธ
๊ด„ํ˜ธ ์•ˆ์— ์•„๋ฌด ๊ฒƒ๋„ ์•ˆ ๋„ฃ์œผ๋ฉด ๋ฐฐ์—ด ๋ณต์‚ฌ

let arr = [1,2,3,4,5]
arr.splice(1,4);
console.log(arr); //[2, 3, 4]

๐Ÿ“Œ arr.concat(arr2, arr3 ..) : ํ•ฉ์ณ์„œ ์ƒˆ ๋ฐฐ์—ด ๋ฐ˜ํ™˜

let arr = [1,2]
arr.concat([3,4]); //[1,2,3,4]
arr.concat([3,4], 5,6); //[1,2,3,4,5,6]

๐Ÿ“Œ arr.forEach(fn) : ๋ฐฐ์—ด ๋ฐ˜๋ณต

forEach(ํ•ด๋‹น ์š”์†Œ, index, ํ•ด๋‹น ๋ฐฐ์—ด ๊ทธ ์ž์ฒด )

let arr = ["Mike", "Tom", "Jane"];
arr.forEach((name, index) => {
  console.log(`${index +1}. ${name}`);
}); 
//1. "Mike", 2. "Tom", 3. "Jane"

๐Ÿ“Œ arr.indexOf/ arr.lastIndexOf

๋ฐฐ์—ด์— ํ•ด๋‹น ์š”์†Œ๊ฐ€ ์žˆ์œผ๋ฉด ํ•ด๋‹น ์š”์†Œ์˜ index ๋ฐ˜ํ™˜, ์—†์œผ๋ฉด -1 ๋ฐ˜ํ™˜
์ธ์†Œ๊ฐ€ ๋‘๊ฐœ์ธ ๊ฒฝ์šฐ ๋‘๋ฒˆ์งธ ์ธ์ˆ˜๋Š” ์‹œ์ž‘ ์œ„์น˜๋ฅผ ์˜๋ฏธ

let = arr[1,2,3,4,5,1,2,3];
arr.indexOf(3); //2
arr.indexOf(3,3) //7
arr.lastIndexOf(3); //7 : ๋์—์„œ๋ถ€ํ„ฐ ์ฐพ๊ธฐ

๐Ÿ“Œ arr.includes() : ํฌํ•จํ•˜๋Š” ์ง€ ํ™•์ธ

index๋ฅผ ํ™•์ธํ•  ํ•„์š” ์—†๊ณ  ํฌํ•จ ์—ฌ๋ถ€๋งŒ ์•Œ๋ ค์คŒ

๐Ÿ“Œ arr.find(fn)/ arr.findIndex(fn) : ์กฐ๊ธˆ ๋” ๋ณต์žกํ•จ, ๋”ฐ๋ผ์„œ ์•ˆ์— ํ•จ์ˆ˜๊ฐ€ ๋“ค์–ด๊ฐ

์ฒซ๋ฒˆ์งธ true๊ฐ’๋งŒ ๋ฐ˜ํ™˜ํ•˜๊ณ  ๋ ๋งŒ์•ฝ ์—†์œผ๋ฉด undefined๋ฅผ ๋ฐ˜ํ™˜
finIndex(fn)์€ ํ•ด๋‹น index๋ฅผ ๋ฐ˜ํ™˜

let = arr[1,2,3,4,5];
const result = arr.find((item) => {
  return item%2 ===0;
});
console.log(result); //2
let userList = [
  {name: "Mike", age:30},
  {name: "Tom", age:27},
  {name: "Jane", age:10},
  ];
userList.find((user)=>{
	if(user.age<19){
    return true;
    }
  return false;
});
console.log(result); //  {name: "Jane", age:10}

๐Ÿ“Œ arr.filter(fn): ๋งŒ์กฑํ•˜๋Š” ๋ชจ๋“  ์š”์†Œ๋ฅผ ๋ฐฐ์—ด๋กœ ๋ฐ˜ํ™˜

find์™€ ์‚ฌ์šฉ๋ฒ•์€ ๋™์ผํ•จ

let = arr[1,2,3,4,5];
const result = arr.filter((item) => {
  return item%2 ===0;
});
console.log(result); [2,4]

๐Ÿ“Œ arr.reverse(): ์—ญ์ˆœ์œผ๋กœ ์žฌ์ •๋ ฌ

๐Ÿ“Œ arr.map(fn) : ํ•จ์ˆ˜๋ฅผ ๋ฐ›์•„ ํŠน์ • ๊ธฐ๋Šฅ์„ ์‹œํ–‰ํ•˜๊ณ  ์ƒˆ๋กœ์šด ๋ฐฐ์—ด์„ ๋ฐ˜ํ™˜

let userList = [
  {name: "Mike", age:30},
  {name: "Tom", age:27},
  {name: "Jane", age:10},
  ];
let newUserList = userList.map((user, index)=>{
	return Object.assign({}, user, {
      id:index+1,
      isAdult: user.age > 19,
    });
});
console.log(newUserList);
//0: {name: "Mike", age:30, id:1, isAdult: true},
//1: {name: "Tom", age:27, id:2, isAdult: true},
//2: {name: "Jane", age:10, id:3, isAdult: false},

๐Ÿ“Œ arr.join(): ๋ฐฐ์—ด์„ ํ•ฉ์ณ์„œ ๋ฌธ์ž์—ด์„ ๋งŒ๋“ค๊ธฐ

์•„๋ฌด๊ฒƒ๋„ ์ „๋‹ฌํ•˜์ง€ ์•Š์œผ๋ฉด ์‰ผํ‘œ๋กœ ๊ตฌ๋ถ„, ๊ณต๋ฐฑ์„ ์ฃผ๊ฑฐ๋‚˜ ํŠน์ˆ˜๋ฌธ์ž๋ฅผ ๋„ฃ์–ด์„œ ๊ทธ๋“ค๋กœ ํ•ฉ์น  ์ˆ˜ ์žˆ์Œ

๐Ÿ“Œ str.split(): ๋ฌธ์ž์—ด์„ ๋‚˜๋ˆ ์„œ ๋ฐฐ์—ด๋กœ ๋งŒ๋“ค๊ธฐ

""๋ฅผ ์ž…๋ ฅํ•˜๋ฉด ๊ฐ ๋ฌธ์ž๋ฅผ ํ•˜๋‚˜์”ฉ ์ž๋ฅธ๋‹ค์Œ์— ๋ฐฐ์—ด๋กœ ๋ฐ˜ํ™˜

๐Ÿ“Œ Array.isArray(): ๋ฐฐ์—ด์ธ์ง€ ์•„๋‹Œ์ง€ ํ™•์ธ

let user = {
  name: "Mike",
  age : 30,
}; //์ผ๋ฐ˜์ ์ธ ๊ฐ์ฒด 
let userList = ["Mike", 30, "Jane"];
console.log(Array.isArray(user)); //false
console.log(Array.isArray(userList)); //true
profile
new blog: https://hae0-02ni.tistory.com/

0๊ฐœ์˜ ๋Œ“๊ธ€