티스토리 뷰
목차
- 객체에 접근하는 3가지방법(콘솔창 TIP, 터미널 단축키)
- 배열과 반복문(querySelector, querySelectorAll)
- 함수의 기본문법(arg, param, return)
소괄호 안의 개념은 같이 설명된 미니개념이라고 생각하시면 됩니다.
의식의 흐름대로 찾은 개념을 정리해놓기도 합니다.
3 ways to access object properties in JS
- Dot property accessor: object.property
- Square brackets property access: object['property']
- Object destructuring: const { property } = object
브라우저 콘솔창TIP
shift 를 누르고 enter를 치면 줄바꿈이 됩니다. JS코드를 적용해볼 때, 명심하세요.
-> enter를 누르면 실행이 되기 때문에 실행되지 않고 여러줄의 JS코드를 실행시켜볼 때 사용하면 좋습니다.
VSCode 터미널 단축키:
`(백틱) + ctrl(컨트롤키)
😎배열과 반복문(Array & Loop)
JS에서 서로 연관된 데이터를 담는 방법 -> 배열
- 배열에 담긴 각각의 항목 = 원소 = element
- 배열에서 어떤 데이터를 가져올 때는 대괄호[]를하고 대괄호 안에 보고싶은 데이터의 index값을 넣어줍니다
- index값은 0부터 시작
담겨있는 배열을 순차적으로 꺼내서 li라는 태그로 만들어주는 역할-> 반복문
활용한 JS코드(수정전)
<script>
let coworkers = ["감자", "고구마", "주먹밥", "모카"];
</script>
<h2>Co workers</h2>
<ul>
<script>
/*i값이 우리가 불러오고자 하는 배열의 index값과 일치하기 때문에 i 를 사용하면 된다.*/
let i = 0;
while (i < 4) {
document.write(`<li>${coworkers[i]}</li>`);
i = i + 1;
}
</script>
->이 코드는 완벽한 코드가 아닌데 이유는 데이터의 값이 바뀌면 정상작동하지 않기 때문에 로직을 바꿔야 한다는 맹점을 가지고 있다. 배열의 수가 바뀔때마다 while안의 조건문을 바꿔줘야 한다는 것이다.
프로그래밍을 할 때, 데이터가 변경된다고 로직을 바꾸는 일은 바람직하지 않습니다.
while의 조건절을 바꿨습니다.
while (i < coworkers.length) {
document.write(`<li>${coworkers[i]}</li>`);
i = i + 1;
}
이로 완성된 코드를 얻게 됐습니다. 만약에 li태그에 링크를 걸고싶다면,
document.write(`<li><a href="http://addf.com">
${coworkers[i]}</a></li>`);
이렇게 내부의 코드를 변경해주면 되는 것이겠죠.
😎배열과 반복문 활용
이전에 우리가 만들던 night_day 버튼 만들기를 이어서 만들어보도록 합시다.
우선 해당 페이지의 모든 a태그를 가져와봅시다.
->전에 배웠던 querySelector()을 사용해서 가져오면 어떨까? 했는데 1개의 요소만 콘솔창에 뜹니다.
- Document.querySelector()는 제공한 선택자 또는 선택자 뭉치와 일치하는 문서 내 첫 번째Element를 반환합니다. 일치하는 요소가 없으면 null을 반환합니다. (MDN 정의)
- 즉, 쿼리셀렉터는 첫번째 요소만 반환하기 때문에 그렇습니다.
- 그렇다면 우리는 뭘 써야할까요? querySelectorAll()을 사용하면 해당 css selector의 모든 노드리스트를 반환합니다. 여기서 노드리스트는 배열이라고 생각하면 쉽습니다.
let alist = document.querySelectorAll('a');
let i = 0;
while (i < alist.length) {
alist[i].style.color = 'powderblue';
i = i + 1;
};
} else {
let alist = document.querySelectorAll('a');
let i = 0;
while (i < alist.length) {
alist[i].style.color = 'blue';
i = i + 1;
};
이 부분을 추가했습니다. 기능은 모든 a태그의 폰트컬러를 나이트_데이 버튼이 눌릴 때, 같이 바뀌는 것인데요.
중요한 것은 변수를 let이 아니라 const로 지정하게 되면 폰트의 색이 변하지 않습니다. 이 점을 명심하세용
😎함수(Function)의 기본
- 입력(parameter, argument) 개념
- 표현식 개념-> return에 연관
- 출력(return) 개념
코드의 중복이 발생하지만 그것이 연속적이지 않을 때는 반복문으로 처리하는 것이 불가능하거나 어려워집니다.
그럴때 우리가 사용하는 것이 함수(Function)입니다.
함수의 기본 모습은 function 함수명() 입니다.
->웹 브라우저는 펑션뒤에 있는 ()소괄호를 보고 앞에있는 것이 function명이고 지금 이 기능을 실행하고 싶구나 라는 걸 알게됩니다.
function two() {
document.write("<li>2-1</li>");
document.write("<li>2-2</li>");
}
document.write("<li>1</li>");
two();
document.write("<li>3</li>");
two();
함수는 입력과 출력으로 이루어져 있습니다.
입력 ->parameter(매개변수), argument(인자) -> 함수로 들어오는 입력값과 관련된 용어들
출력 ->return
function sum(왼쪽값, 오른쪽값) { //매개변수=param
document.write(왼쪽값 + 오른쪽값);
}
sum(27, 11); //인자arg
->function을 실행시킬 때 받는 값 -> 함수로 전달하는 27과 11이라는 값이 argument(인자)입니다.
여기서 왼쪽값, 오른쪽값이 arg를 받아서 함수 안으로 매개해주는 변수라서 매개변수라고 부릅니다.
▶argument(인자)를 받아서 function(함수)로 보내주고 그 값을 parameter(매개변수)로 받은 함수가
연산해서 return값을 돌려준다.(위의 코드에서는 return을 하고 있진 않습니다. 아래서 return을 다룹니다.)
👻return
이 개념을 하기 전에 표현식에 대해서 알아보겠습니다.
2-1
//expected output 1
1===1
//expected output true
풀어서 설명하면
2-1은 1이라는 값의 표현식이고,
true라는 값의 표현식은 1===1인 것입니다.
sum2(2,3)을 했을 때 5가 되는 표현식을 만들고 싶으면 return이라는 개념을 잘 알고 있어야 합니다.
<script>
function sum2(left, right) {
return left + right;
}
document.write(sum2(2, 3) + "<br>");
document.write('<div style="color:red">' + sum2(2, 3) + "</div>");
document.write('<div style="font-size:3rem;">' + sum2(2, 3) + "</div>");
</script>
우리가 이전에 만들었던 sum() 함수는 값을 되돌려주는 것이 아니라 내부에서 document.write()를 통해 실행하고 있습니다. 그렇게 되면 sum()함수의 결과값을 가지고 다른 일을 할 수 없고 함수의 결과를 이어받아 다른 기능을 구현하려면 일일이 새로운 fucntion을 만들어줘야하기 때문에 자유도가 떨어지게 됩니다. 하지만, return을 통해 값을 돌려줌으로써 새로운 function을 만들지 않고도 sum2()을 다양한 맥락에서 사용할 수 있는 자유도가 생깁니다.
'Frontend > JavaScript' 카테고리의 다른 글
[javaScript] 색상을 담은 배열로 배경색상 변경하기 (0) | 2021.12.24 |
---|---|
[생활코딩][JavaScript] 자바스크립트 기초3 (0) | 2021.12.15 |
[생활코딩][JavaScript] 자바스크립트 기초1 (0) | 2021.12.13 |
[JavaScript]#27 날씨정보 표기하기(날씨API 사용해보기),fetch() (0) | 2021.12.02 |
[JavaScript]#26 todo list만들기5(투두 리스트 삭제하고 업데이트하기2), filter() (0) | 2021.12.02 |
- Total
- Today
- Yesterday
- nvm경로 오류
- getServerSideProps
- getStaticPaths
- tilde caret
- 프리렌더링확인법
- aspect-ratio
- && 셸 명령어
- ~ ^
- 형제 요소 선택자
- text input pattern
- fs모듈 넥스트
- nvm 설치순서
- D 플래그
- 타입스크립트 DT
- 틸드와 캐럿
- is()
- 프리온보딩 프론트엔드 챌린지 3월
- 항해99프론트
- reactAPI
- 원티드 FE 프리온보딩 챌린지
- grid flex
- float 레이아웃
- 항해99추천비추천
- Prittier
- 원티드 프리온보딩 프론트엔드 챌린지 3일차
- 부트캠프항해
- 타입스크립트 장점
- 항해99프론트후기
- 원티드 3월 프론트엔드 챌린지
- 원티드 프리온보딩 FE 챌린지
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |