본문 바로가기

분류 전체보기94

JavaScript - 알고리즘 특강(쉽게 진수변환, map & set) toString, parseInt 이용해 아주 쉽게 진수변환하기 toStirng() 특정 객체를 문자열로 반환해준다. 10진수를 다른 진수로 변환하기 위해서 사용할 수 있다. * 10진수 -> 16진수 var dec = 123; var hex = dec.toString(16); // === "7b" * 10진수 -> 2진수 var dec = 123; var bin = dec.toString(2); // === "1111011" parseInt() 문자열을 특정 진수의 정수로 변환한다. 다른 진수를 10진수로 변환시키기 위해서 사용할 수 있다. * 16진수 -> 10진수 var hex = "7b"; var dec = parseInt(hex, 16); // === "123" 알고리즘 문제 풀이시 유용한 ma.. 2024. 2. 28.
TIL #24) 커스텀 에러 만들기 Today I Learned 3계층 분리를 하며 에러 처리를 단순히 한 파일 안에서 하는것이 힘들어졌다. 기본적으로 3계층이라 하면 컨트롤러 - 서비스 - 레파지토리 순으로 하게 되는데, request 와 response를 담당하는건 컨트롤러 계층이기 때문에 직접적으로 에러 코드를 띄우고 http method를 사용하고싶다면 컨트롤러 계층을 이용해야 한다. 원래는 서비스 계층에서 에러가 발생시, 예시와 같이 만들고 컨트롤러에서 만약 에러 메시지가 이렇다면 해당 에러를 띄우도록 하는 방식을 사용했다. throw ({ code: 404, message: "찾으시는 페이지가 존재하지않습니다.", )} 이것보다 편하게 에러를 만들 수 있는 방식이 바로 커스텀 에러이다. export class Validation.. 2024. 2. 27.
TIL #23) 커버리지 보고서 Today I Learned 커버리지를 이용하면 jest 테스트 코드 보기가 편하다는데,, 커버리지가 대체 뭔데 그런 도움을 준다는거죠? 라는 의문이 들어 찾아보게 되었다. Jest 커버리지 보고서란 저 사진의 모습으로 정리된!! 보기좋은 모습의 보고서를 말한다. % Stmts (문장 커버리지 비율): 코드 파일에서 테스트된 코드 문장의 비율을 나타냅니다. 예를 들어, 80%의 문장 커버리지는 코드 파일에서 100줄 중 80줄이 테스트되었음을 의미합니다. % Branch (분기 커버리지 비율): 코드 파일에서 테스트된 분기(조건 분기)의 비율을 나타냅니다. 예를 들어, 75%의 분기 커버리지는 코드 파일에서 100개의 조건 분기 중 75개가 테스트되었음을 의미합니다. % Funcs (함수 커버리지 비율).. 2024. 2. 22.
프로그래머스 JavaScript - 숫자 문자열과 영단어 문제 네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다. 다음은 숫자의 일부 자릿수를 영단어로 바꾸는 예시입니다. 1478 → "one4seveneight" 234567 → "23four5six7" 10203 → "1zerotwozero3" 이렇게 숫자의 일부 자릿수가 영단어로 바뀌어졌거나, 혹은 바뀌지 않고 그대로인 문자열 s가 매개변수로 주어집니다. s가 의미하는 원래 숫자를 return 하도록 solution 함수를 완성해주세요. 참고로 각 숫자에 대응되는 영단어는 다음 표와 같습니다. 1 ≤ s의 길이 ≤ 50 s가 "zero" 또는 "0"으로 시작하는 경우는 주어지지 않습니다. retur.. 2024. 2. 22.
TIL #22) test code - 의존성 주입하기 Today I Learned 오늘은 과제 1차 제출일이다. 필수구현사항을 다 하지 못하고 낸게 큰 충격.. 뭔가 정말 열심히 시간을 많이 들였다면 시간내에 다 했을 수도 있을것 같은데, 이상하게 이번 과제는 너무 손 대기가 싫었다.. 그게 결국 잘 모르는거라서, 어려워서 이해하기 싫어서 그랬던 거겠지. 어려운걸 붙잡고있으니까 자신감이 떨어지는 기분이 든다.. 그래도 TIL도 결국 오늘 하루 더 알게된것에 대해 쓰는거니까! 다들 이런 기분을 공유하는것 같아 조금은 위로가 됐다. 다들 힘냅시다.. 실제로 테스트 코드를 잘 아는사람들은 많이 없어서 깊이 파게되면 취업에도 도움이 된다한다. 마음을 다잡고 가보자고 🤯 궁금한 것 & 알아낸 것 - mock fucntion 특정 메서드가 몇번 실행됐는지 아는게 뭐가.. 2024. 2. 22.
TIL #21) 기존코드 3계층 분리하기 Today I Learned 3 layered architecture 가보자고!! 1. 컨트롤러 응답과 요청을 처리. 인증미들웨어도 여기서 처리 2. 서비스 레포지토리에서 가져온 정보를 어떻게 사용자에게 보여줄지(정렬, 뭘 보여줄지 select) 조각조각 정리 3. 레포지토리 프리즈마에서 직접적으로 정보 가져옴 웨어를 통해 어떤 정보 가져올지 선택 가능 == 내가 이해한것 == 컨트롤러에서 요청받은값을 => 서비스에 보내고 서비스에서 받은값을 => 리턴으로 내보내고 서비스에서는 컨트롤러에서 받은값을 => 레포지토리로 보내고 레포지토리에서 받아온값을 가공해 => 컨트롤러에게 보내고 레포지토리는 서비스에서 받아온값을 => 프리즈마에서 가져오고 프리즈마에서 가져온 정보를 => 서비스로 보내고 ===== 레파지.. 2024. 2. 21.
TIL #20) 객체 지향 프로그램 Today I Learned 상속 상속은 객체 지향 프로그래밍에서 클래스 간의 관계를 정의하는 중요한 개념. 상속을 통해 기존 클래스의 속성과 메서드를 물려받아 새로운 클래스를 정의할수있고, 똑같은 코드를 계속 반복할 필요가 없다. 상속을 구현하려면 extends 키워드를 사용하면 가능~! class Animal { //부모클래스 name: string; constructor(name: string) { this.name = name; } makeSound() { console.log('동물 소리~'); } } class Dog extends Animal { //자식클래스 age: number; constructor(name: string) { super(name); this.age = 5; } make.. 2024. 2. 19.
TIL #19) 객체 지향 설계 5원칙(SOLID) SOLID 객체 지향 프로그래밍 및 설계의 다섯가지 핵심원칙 SOLD 원칙을 따르면 시간이 지나도 유지보수와 확장이 쉬운 시스템을 구축할 수 있다. 단일 책임의 원칙 개방 - 폐쇄 원칙 리스코프 치환 원칙 인터페이스 분리 원칙 의존성 역전 원칙 단일 책임의 원칙 Single Responsibility Principle, SRP 하나의 객체는 단 하나의 책임을 가져야 한다. 즉, 클래스나 모듈을 변경할 이유가 단 하나 뿐이어야한다는 원칙. 동작하기만 하는 소프트웨어 보다 깨끗하고 우아하게 작성된 소프트웨어!! 개방 - 폐쇄 원칙 Open - Closed Principle, OCP 소포트웨어 엔티티 또는 개체는 확장에는 열려있으나 변경에는 닫혀 있어야 한다. 기존 코드에 영향을 주지않고 소프트웨어에 새로운 .. 2024. 2. 16.
프로젝트 회고 우리동네 동아리(우동) 같은취미를 가진 사람들과 모여 동아리를 개설하고, 게시글 또는 댓글로 반응이 가능한 뉴스피드 프로젝트 회원가입시 입력한 관심사를 기반으로 모임을 추천 받을 수 있는 기능이 있으며, 유저들간 팔로우 또한 가능하다. 작업기간 2/8 ~ 2/14 발표자료 시연 영상 https://youtu.be/Q1-tJS5b10A?si=aCp0zaKAduO5fl8v api 구현, 일부지만 프론트 작업한것, 카카오 로그인, 노드메일러를 이용한 메일 인증 기능을 담은 영상이다. 피드백 기본기능을 충실하게 구현 잘 했다. 관심사 기반 추천 기능 외에 로그인 하지 않은 사용자를 위한 랜덤조회 기능까지 서비스 고민에 대한 흔적이 보여 좋았다. 아쉬웠던점은 불필요한 컬럼이 많았다는것. 이것들을 정리하면 좋겠다는.. 2024. 2. 15.