Frontend 개발자 - hyo.loui

모던 javascript - 배열 메서드 본문

Javascript

모던 javascript - 배열 메서드

hyo.loui 2023. 3. 27. 04:32

❤️‍🔥TIL : Today I Learned

배열 메서드

배열에는 원본배열을 직접 변경하는 메서드와
배열을 직접 변경하지 않고 새로운 배열을 생성하여 반환하는 메서드가 있다.

 

https://doesitmutate.xyz/

 

Does it mutate?

The lastIndexOf() method returns the last index at which a given element can be found in the array, or -1 if it is not present. The array is searched backwards, starting at fromIndex.Array.prototype.lastIndexOf ( searchElement [ , fromIndex ] )

doesitmutate.xyz


mutator  method?  accetor method?

 

예제를 먼저 살펴보자

const 두시반에만든배열 = [1];

두시반에만든배열.push(2);

console.log(두시반에만든배열);  // [1,2]

 

 

const 세시에만든배열 = 두시반에만든배열.concat(3);

console.log(두시반에만든배열);  // [1,2]
console.log(세시에만든배열);  // [1,2,3]

 

.push 메서드는 두시반에만든배열을 직접 변경하여 값이 변하였고.

.concat 메서드는 세시에만든배열을 변경하지 않고 값을 따로 복사해 왔다.

 

원본 배열을 직접 변경하는 메서드는 외부 상태를 직접 변경하는 부수 효과가 있으므로 사용시 주의해야 한다.

따라서 가급적 원본 배열을 직접 변경하지 않는 메서드를 사용하는 편이 좋다.


isArray (=너 배열이냐?)

 

 

- 배열은 타입으로 나타나지 않고 object 이기 때문에 typeof 연산자를 사용하지 못한다.

- 따라서 isArray를 사용하면 boolean 으로 구분이 가능하다.

Array.isArray([]);  // true
Array.isArray([1, 2]);  // true

Array.isArray(); // false
Array.isArray({}); // false
Array.isArray(null); // false
Array.isArray(1); // false
Array.isArray('Array'); // false

 


indexOf (=너 몇번째임?)

 

 

- 요소를 검색하여 인덱스를 반환합니다. (너무 좋은 메서드)

const 성적표 = ['윤준호', '이승효']

성적표.indexOf('이승효');  // 1 (등) ㅋㅋ

 

오렌지가 없으면 -1을 반환합니다. 그래서 -1이라면 오렌지를 넣어주도록 만들었습니다.

const 과일바구니 = ['사과', '바나나'];

if(과일바구니.indexOf('오렌지') === -1) {
	과일바구니.push('오렌지');
}

console.log(과일바구니); // ['사과', '바나나', '오렌지']

 

하지만 includes 메서드를 사용하면 가독성이 더 좋습니다.

const 좋아하는색 = ['흰색'];

if(!좋아하는색.includes('검은색')) {
	좋아하는색.push('검은색')
}

console.log(좋아하는색);  // ['흰색','검은색']

push (=배열에 따라 붙어)

mutates

.

const 새벽세시에만든배열 = [1, 2];

let 졸면서만든배열 = 새벽세시에만든배열.push(3,4);
console.log(졸면서만든배열);  // 4
// 의도한 것과 다름... 원본배열의 변경된 length 값을 반환

console.log(새벽세시에만든배열); // [1, 2, 3, 4]

pop (=넌 빠져..)

mutates

 

const 두개짜리배열 = [1, 2];

let 뽑은거 = 두개짜리배열.pop();
console.log(뽑은배열); // 2;

console.log(두개짜리배열);  // [1]

unshift (=새치기 개꿀잼)

mutates

 

const 선착순 = [1, 2];

let 나쁜친구들 = 선착순.unshift(3,4);

console.log(나쁜친구들);  // 4 == push처럼 변경된 length값을 반환

console.log(선착순);  // [3, 4, 1, 2]

shift (=1등 열외)

mutates

 

const 뺑뺑이 = ['윤준호', '이승효', '조희현', '김남규']

let 일등 = 뺑뺑이.shift();
console.log(일등); // '윤준호'

console.log(뺑뺑이)  // ['이승효', '조희현', '김남규']

 


concat (= 합체)

 

const num1 = [1, 2, 3];
const num2 = [4, 5, 6];
const num3 = [7, 8, 9];

const numbers = num1.concat(num2, num3);

console.log(numbers);
// results in [1, 2, 3, 4, 5, 6, 7, 8, 9]

const letters = ["a", "b", "c"];
const numbers = [1, 2, 3];

const alphaNumeric = letters.concat(numbers);
console.log(alphaNumeric);
// results in ['a', 'b', 'c', 1, 2, 3]

+ concat 보다는 전개연산자(스프레드 문법)으로 대체 가능


splice (= 삽입? 삭제? 수정? 별거아님ㅋ)

mutates

 

// ---------- 삽입 ----------
const fruits = ['수박', '바나나', '망고', '두리안'];

const removed = fruits.splice(2, 0, '딸기', '사과');

console.log(fruits);
// ['수박', '바나나', '딸기', '사과', '망고', '두리안'];

console.log(removed);
// [];

// ---------- 삭제 ----------
const fruits = ['수박', '바나나', '망고', '두리안'];

const removed = fruits.splice(2, 1);

console.log(fruits);
// ['수박', '바나나', '두리안'];

console.log(removed);
// ['망고'];

// ---------- 수정 ----------
const fruits = ['수박', '바나나', '망고', '두리안'];

const removed = fruits.splice(1, 2, '멜론');

console.log(fruits);
// ['수박', '멜론', '두리안'];

console.log(removed);
// ['바나나', '망고'];

 


slice (= 복사)

 

.

const numbers = [1, 2, 3, 4, 5];
// 양수 index    0, 1, 2, 3, 4

console.log(numbers.slice()); // index 0부터 추출(0, undefined, null 동일 동작) 
// expected : [1, 2, 3, 4, 5] 얕은복사 가능!!!!!

console.log(numbers.slice(1)); // index 1부터 추출
// expected : [2, 3, 4, 5];

console.log(numbers.slice(-2)); // 마지막요소부터 마지막에서 두번째 요소까지 추출
// expected : [4, 5];

console.log(numbers.slice(99)); // 배열의 길이보다 클 경우 빈 배열
// expected : [];


console.log(numbers.slice(1, 4)); // index 1부터 index 4까지(index 4제외) 추출
// expected : [2, 3, 4];

console.log(numbers.slice(2, -1)); // index 2부터 마지막에서 첫번째 요소까지(마지막에서 첫번째 요소 제외) 추출
// expected : [3, 4];

console.log(numbers.slice(2, 99)); // index 2부터 마지막에서 요소까지 추출(end가 배열의 길이보다 큼)
// expected : [3, 4, 5];

join (= 너와 나의 연결 고리 그건 우리 안의 , )

 

const 배열입니다 = [1, 2, 3, 4];

배열입니다.join(); // '1,2,3,4';

배열입니다.join(''); // '1234';

배열입니다.join(':'); // '1:2:3:4';

reverse (= 어퍼)

mutates

 

const 빠따맞는순서 = [1,2,3];
const 형들부터 = 빠따맞는순서.reverse();

console.log(빠따맞는순서); [3,2,1]
console.log(형들부터); [3,2,1]

fill (= 필라이트 아니고 필메서드)

mutates

const array1 = [1, 2, 3, 4];

// 술마신사람 0으로
console.log(array1.fill(0));
// Expected output: Array [0, 0, 0, 0]

console.log(array1.fill(0, 2, 4));
// Expected output: Array [1, 2, 0, 0]

console.log(array1.fill(5, 0));
// Expected output: Array [1, 0, 0, 0]

includes (=이거 들어있음?)

 

const 내지갑 = ['오만원', '천원']

내지갑.includes('오만원');  // true
내지갑.includes('수표');  // false

flat (= 배열안에 숨어있는놈들 나와)

 

 

const 좋은말로할때나와1 = [1, 2, [3, 4]];
좋은말로할때나와1.flat();
// [1, 2, 3, 4]

const 좋은말로할때나와2 = [1, 2, [3, 4, [5, 6]]];
좋은말로할때나와2.flat();
// [1, 2, 3, 4, [5, 6]]

const 기회는세번뿐 = [1, 2, [3, 4, [5, 6]]];
기회는세번뿐.flat(2);
// [1, 2, 3, 4, 5, 6]

 

하지만, 간편하게 쓸 수 있는 flat() 은 브라우저에 최적화가 되있지 않은 상태이므로

[].concat() 을 사용하는 것이 속도면에서 더 유리하다.

 

 


 

 최종 정리

  1. isArray = 너 배열이니?    return boolean
  2. indexOf = 너 몇번째임?    return index 순번
  3. push = 배열에 따라 붙어    return 변경된 배열 length값
  4. pop = 배열 마지막 떼어네기    return 떼어넨 값
  5. unshift = 배열 맨앞 새치기    return 변경된 배열 length값
  6. shift = 일등 빠져    return 배열의 첫번째 값
  7. concat = 배열 합치기     return 합쳐지고 새로운 배열
  8. splice = 삽입, 삭제, 수정 가능    return 배열에서 떼어넨 값
  9. slice = 복사 가능    return 복사한 값
  10. join = 배열을 문자열로    return 문자열
  11. reverse = 배열 거꾸로    return 거꾸로 된 배열
  12. fill = 배열 채우기     return 지정된 값으로 채운 값
  13. includes = 배열 요소에 있는지 확인     return boolean
  14. flat = 배열안에 배열 꺼내기    return 기본값은 1 depth.