[240421] 32장 String

String 생성자 함수

  • new 연산자와 함께 호출하여 String 인스턴스 생성 가능
  • [[ StringData ]] 내부 슬롯에 빈 분자열을 할당한 String 래퍼 객체 생성
  • string 래퍼 객체는 배열과 마찬가지로 length 프로퍼티와 인덱스를 나타내는 숫자 형식의 문자열 프로퍼티 키로, 문자를 프로퍼티 값으로 갖는 유사 배열 객체이면서 이터러블이다.
  • new 를 사용하지 않으면 String 인스턴스가 아닌, 문자열을 반환함

    → 명시적으로 타입을 변환하기도 함

const strObj = new String();
console.log(strObj); // String {length: 0, [[PrimitiveValue]]: ""}

length 프로퍼티

  • 문자열의 문자 개수 반환
'Hello'.length; // 5
'안녕하세요!'.length // 6

String 메서드

  • String 객체는 원본 String 래퍼 객체를 직접 변경하는 메서드는 존재 X, 언제나 새로운 문자열 반환함
  • 문자열은 변경 불가능한 원시 값이기 때문에 String 래퍼 객체도 읽기 전용으로 제공됨

1. String.prototype.indexOf

  • 대상 문자열 검색하여 첫번째 인덱스 반환, 실패 시 -1

2. String.prototype.search

  • 전달받은 정규 표현식과 매치하는 문자열을 검색하여 일치하는 문자열의 인덱스 반환

3. String.prototype.includes

  • ES6에서 도입
  • 인수로 전달받은 문자열이 포함되어있는지 확인
  • true, false 반환

4. String.prototype.startsWith

  • ES6 도입
  • 인수로 전달 받은 문자열로 시작하는지 확인
  • 결과 true, false 반환

5. String.prototype.endsWith

  • ES6 도입
  • 인수로 전달 받은 문자열로 끝나는지 확인

6. String.prototype.charAt

  • 대상 문자열에서 인수로 전달받은 인덱스에 위치한 문자를 검색하여 반환

7. String.prototype.subString

  • 첫번째 인수부터 두번째로 전달받은 인덱스의 위치 이전 문까지 부분 문자열을 반환

8. String.prototype.slice

  • substring 이랑 동일하게 동작
  • 단 slice 에서는 음수인 인수를 전달 가능
  • 뒤에서부터 시작하여 문자를 잘라냄
const str = 'hello world';
str.substring(-5); // 0 으로 취급 'hello world'
str.slice(-5); // 뒤에서 5자리 잘라냄 'world'

9. String.prototype.toUpperCase

  • 문자 모두 대문자로 변경

10. String.prototype.toLowerCase

  • 문자 모두 소문자로 변경

11. String.prototype.trim

  • 공백 문자가 있을 경우, 제거한 문자열 반환

12. String.prototype.repeat

  • 인수로 전달받은 정수만큼 반복해 연결한 새로운 문자열을 반환
  • 기본값은 0
  • 0이면 빈 문자열 반환
const str = 'abc';

str.repeat(); // ''
str.repeat(2); // 'abcabc'

13. String.prototype.replace

  • 첫번째 인수로 전달받은 문자열 또는 정규표현식을 두번째 인수로 반환
  • 여러개 존재할 경우 첫 번째 검색된 문자열만 치환

14. String.prototype.split

  • 첫 번째 인수로 전달한 문자열 또는 정규 표현식을 검색하여 문자열을 구분한 후 분리된 각 문자열로 이루어진 배열 반환

Categories:

Updated:

Leave a comment