1단계 new_id의 모든 대문자를 대응되는 소문자로 치환합니다.
2단계 new_id에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.)를 제외한 모든 문자를 제거합니다.
3단계 new_id에서 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환합니다.
4단계 new_id에서 마침표(.)가 처음이나 끝에 위치한다면 제거합니다.
5단계 new_id가 빈 문자열이라면, new_id에 "a"를 대입합니다.
6단계 new_id의 길이가 16자 이상이면, new_id의 첫 15개의 문자를 제외한 나머지 문자들을 모두 제거합니다.
     만약 제거 후 마침표(.)가 new_id의 끝에 위치한다면 끝에 위치한 마침표(.) 문자를 제거합니다.
7단계 new_id의 길이가 2자 이하라면, new_id의 마지막 문자를 new_id의 길이가 3이 될 때까지 반복해서 끝에 붙입니다.

[문제]

신규 유저가 입력한 아이디를 나타내는 new_id가 매개변수로 주어질 때, "네오"가 설계한 7단계의 처리 과정을 거친 후의 추천 아이디를 return 하도록 solution 함수를 완성해 주세요.

[제한사항]

new_id는 길이 1 이상 1,000 이하인 문자열입니다.new_id는 알파벳 대문자, 알파벳 소문자, 숫자, 특수문자로 구성되어 있습니다.new_id에 나타날 수 있는 특수문자는 -_.~!@#$%^&*()=+[{]}:?,<>/ 로 한정됩니다.

[입출력 예]

function solution(new_id) {
  var answer = '';
  answer = new_id
    .toLowerCase()  << 문자를 소문자로 변경
    .replace(/[^\\w-_.]/g, '')  // 모든단어와 - _ . 를 뺀 나머지를 공백처리
    .replace(/\\.{2,}/g, '.')  //.이 두개이상일경우 .으로 변경
    .replace(/^\\.|\\.$/g, '')  // ^ < 문자열시작의미 & 문자열 종료의미 
	                                         >> . 시작이나 마지막위치에 있을때 공백처리
    .replace(/^$/g, 'a')      // 공백일경우 a대입
    .slice(0, 15)             // 0~15 글자까지 사용가능
    .replace(/\\.$/g, '');     // slice로 16글자 제거후 마지막에 .이 있으면 . 공백처리
  return answer.length > 2   //answer글자가 2글자 이상이면 answer출력   
    ? answer //아니면 answer + answer[answer.length - 1].repeat(3 - answer.length); 출력
    : answer + answer[answer.length - 1].repeat(3 - answer.length);
	//repeat() 함수는 주어진 문자열을 옵션의 count 만큼 반복하여 붙인 다음에 
                                                         새로운 문자열로 반환하는 함수
} 

1단계 new_id의 모든 대문자를 대응되는 소문자로 치환합니다.

        answer = new_id.toLowerCase()

.toLowerCase() 를 사용하여 모든 문자를 소문자로 변경

✅ .toLowerCase() : 문자를 소문자로 바꿔주는 함수

2단계 new_id에서 알파벳 소문자, 숫자 - _ . 를 제외한 모든 문자를 제거합니다.

answer = new_id.replace(/[^\\w-_.]/g, '')