-
Notifications
You must be signed in to change notification settings - Fork 7
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[1주차] 심여은 미션 제출합니다. #5
base: main
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
안녕하세요 여은 님!
굉장히 짧은 시간이었음에도 정말 완성도 높은 결과물을 구현하셨네요 🥹 정말 고생 많으셨습니다! 진짜 노트패드 같아요 🗒️🗒️ 코멘트도 간단히 몇 개 달아 봤습니다 👀 (프리티어 설정이 제대로 안 된 것 같은데 확인 한번 부탁드립니다!)
script.js
Outdated
function setTodoList(todo) { | ||
let newTodoList = getTodoList(); | ||
//todo done 여부 확인 | ||
for (let i = 0; i < newTodoList.length; i++) { | ||
if ( | ||
newTodoList[i].content === todo.content && | ||
newTodoList[i].complete !== todo.complete | ||
) { | ||
newTodoList.splice(i, 1); | ||
break; | ||
} | ||
} | ||
newTodoList.push(todo); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
이 부분을 JavaScript의 배열 내장 함수를 사용하여 자바스크립트 답게 작성해 보면 좋을 것 같아요! 또한 JavaScript에서 배열을 사용할 때 splice()
나 push()
를 사용하는 것보다는 새로운 배열을 만들어 할당하는 방식을 자주 사용합니다 🙂
그 이유가 궁금하시다면,,,
JS의 immutability(불변성) 관련된 문제인데 이 글에 자세히 나와 있어서 참고하시면 좋을 것 같아요!
간단히 설명드리자면, 배열의 값을 직접 변경할 경우 디버깅이 어렵고 의도치 않은 결과를 불러올 수 있기 때문에 배열의 값을 직접 변경하는 방식이 아닌 새로운 배열을 만들어 할당하는 방식을 추천합니다. 따라서 값을 직접 변경하는 push()
, splice()
등의 메소드보다 새로운 배열을 반환하는 map()
, filter()
혹은 spread
연산자를 사용하는 방식을 권장합니다 👀 또한 나중에 React를 사용하실 때에도 배열 불변성을 지켜 주셔야 상태 변화 감지와 성능 최적화 부분에서 용이하답니다!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
저도 주현님께서 말씀해주신 것과 같이 배열 내장 함수를 사용하는 것이 좋을 것 같습니다! 훨씬 간결해질 것 같습니다!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
배열 내장 함수 바로 적용해서 자바에서 자바스크립트로 업그레이드 해보겠습니다!
JS의 불변성에 대해서는 잘 몰랐는데, react에서 state 객체에 불변성을 적용하는 것도 같은 맥락이네요! 또 새롭게 알아갑니다😀
splice()를 사용한 코드는 map()을 사용해서 리팩토링해보겠습니다!
script.js
Outdated
newTodoList.splice(index, 1); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
여기도 추후에 filter()
메서드를 사용해 보면 좋을 것 같아요!
font-family: RixXladywatermelonR; | ||
display: flex; | ||
justify-content: center; | ||
align-content: center; | ||
flex-wrap: wrap-reverse; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
cursor: pointer
를 추가하면 더 좋을 것 같습니다 😉
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
오 버튼에 추가해보겠습니다!
script.js
Outdated
if (todo.complete) { | ||
newDoneBtn.innerText = "v"; | ||
doneListElement.appendChild(newLi); | ||
} else { | ||
newDoneBtn.innerHTML = " "; | ||
todoListElement.appendChild(newLi); | ||
} | ||
|
||
newDeleteBtn.textContent = "x"; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
innerText와 textContent를 구분해서 사용하신 이유가 있으신가요 ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
앗 따로 이유는 없습니다! 코드를 꼼꼼하게 확인하지 못해서 같은 기능에 다른 속성을 사용하고 있었네요ㅠㅠ😮💨 확인 감사합니다!🙇🏻♀️
button 엘리먼트 하나의 텍스트값만 읽어오니까 innerText로 통일해서 사용하는게 맞겠네요!
감사합니다🙇🏻♀️🙇🏻♀️ 디자인에 고민을 많이 했는데 노트패드같다니 정말 다행이에요...!! 프리티어는 vs익스텐션만 설치하면 된다고 생각했는데 설정이 더 있었네요😅 주현님이 주신 노션페이지 참고해서 설정했습니다!! |
코드가 기능 단위로 잘 나누어져 있어서 금방 흐름이 읽혔어요! 고생하셨습니다 ㅎㅎ |
script.js
Outdated
function setTodoList(todo) { | ||
let newTodoList = getTodoList(); | ||
//todo done 여부 확인 | ||
for (let i = 0; i < newTodoList.length; i++) { | ||
if ( | ||
newTodoList[i].content === todo.content && | ||
newTodoList[i].complete !== todo.complete | ||
) { | ||
newTodoList.splice(i, 1); | ||
break; | ||
} | ||
} | ||
newTodoList.push(todo); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
저도 주현님께서 말씀해주신 것과 같이 배열 내장 함수를 사용하는 것이 좋을 것 같습니다! 훨씬 간결해질 것 같습니다!
} | ||
|
||
li > :nth-child(3) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
css 정석대로 야무지게 잘 사용하시네요 멋집니다!
Co-authored-by: Joohyun Kim <[email protected]>
미션 소감
안녕하세요, LG U+유레카 1기 프론트엔드 반 심여은입니다.
다른 분들보다 좀 더 늦게 첫 번째 과제를 마쳤습니다 😭 저번 미니 프로젝트 때 투두 리스트를 만들어 본 경험이 있어 이번에도 쉬울 것이라고 생각했는데, localStorage를 이용하는 방식이 익숙치 않아 이 방법이 맞나 하며 여러번 코드를 고쳤던 것 같습니다ㅠㅠ
상태 관리를 보다 쉽게 할 수 있는 리액트가 눈에 아른거렸지만... 이번 과제 덕분에 JS에서 DOM 엘리먼트를 접근하는 방식이 조금 더 익숙해진 것 같아서 자신감이 약간 붙었습니다!
다음 과제는 미리 준비해서 시간에 쫓기지 않도록 하겠습니다...! 또한 작성한 코드에 미숙한 부분이 있다면 마구마구 리뷰 달아주세요!!
미션에서 특별히 신경 쓴 부분들
+스터디장님의 예시를 보고 vercel로 배포해봤습니다! https://vanilla-todo-ongheong.vercel.app/
KEY QUESTION
1. DOM이란 무엇인가요?
DOM은 웹페이지의 요소를 트리 형태로 구조화시켜 표현한 것으로, 프로그래밍 언어가 쉽게 접근하여 웹페이지의 요소를 변형할 수 있도록 api를 제공하는 인터페이스입니다. 웹 브라우저에서 DOM을 조작하기 위해서는 JS를 사용해야 합니다.
2. JavaScript로 DOM을 조작하는 방법은 어떤 것이 있나요?
여러 방법들이 있으며, 주로 사용하는(제 프로젝트에서 사용된 것 위주로) 방법은 다음과 같은 것들이 있습니다.
등등...
3. Semantic tag에는 어떤 것이 있으며, 이를 사용하는 이유는 무엇일까요?
사실 시멘틱 태그는 이번에 처음 사용해봤습니다! 사용해보면서 조금 정리한 내용을 적어보겠습니다.
data:image/s3,"s3://crabby-images/58580/5858094f790560a2cd2ea1c3721a00518911df4f" alt="image"
시멘틱 태그는 태그 안에 포함된 콘텐츠의 특정 의미를 정의하고 목적을 갖는 태그입니다. 때문에 사용하면 더 명시적이고 직관적인 구조의 설계가 가능해집니다. 태그의 종류는 밑의 사진을 참고해주세요! 참고로 이번 프로젝트에서 저는 header, section 태그를 사용해봤습니다.
data:image/s3,"s3://crabby-images/c0196/c0196ee3664fd0e32f1c98133dfc63cb2a067a3b" alt="image"
4. Flexbox Layout은 무엇이며, 어떻게 사용하나요?
Flexbox는 웹페이지 레이아웃을 유연하고 효율적으로 관리할 수 있는 도구입니다. 요소를 수직/수평으로 정렬하고, 공간을 분배하고, 컨텐츠의 크기를 동적으로 조절할 수 있게 해줍니다. 주요 속성은 다음과 같은 것들이 있습니다.
flex
/inline-flex
를 설정하여 Flex Container를 정의함row
,column
등flex-start
,flex-end
,center
,space-between
,space-around
,space-evenly
flex-start
,flex-end
,center
,baseline
,stretch
nowrap
,wrap
,wrap-reverse
위 속성들을 이용해 다음과 같이 css에 적용해볼 수 있습니다.