2019/10/08 - [JavaScript/초보자를 위한 자바스크립트] - 초보자를 위한 자바스크립트 커리큘럼

2019/10/14 - [JavaScript/초보자를 위한 자바스크립트] - +자바스크립트 - html과 css를 가볍게 알아보자!

 

2019/10/02 - [JavaScript/초보자를 위한 자바스크립트] - 1. 초보자를 위한 '자바스크립트는 무엇인가?' (feat.프로그래밍을 배우고 싶다면)

2019/10/08 - [JavaScript/초보자를 위한 자바스크립트] - 2. 자바스크립트 변수(variable)와 자료형(data type)

2019/10/14 - [JavaScript/초보자를 위한 자바스크립트] - 3. 자바스크립트 - 비교연산자(Comparisons)와 조건문(Conditional operators)

2019/11/19 - [JavaScript/초보자를 위한 자바스크립트] - 4. 자바스크립트 - 배열(Array)와 반복문(loop)


함수(Fuction)란?

이번 시간에는 자바스크립트(JavaScript)에서 '함수'에 대해 배워보도록 하겠습니다.

함수는 하나의 로직을 재실행할 수 있도록 하는 것입니다. 이러한 함수를 이용해서 반복되는 동일한 작업을 필요할 때마다 불러와서 사용할 수 있습니다. 이러한 것을 '코드 재사용'이라고 하기도 합니다. 한번 만들어둔 함수를 계속해서 불러와서 다시 사용할 수 있기 때문이죠.

 

함수는 1. 함수를 선언하기 2. 함수를 호출하기  [각주:1]이 두가지로 이루어집니다. 함수 선언 = 함수를 만든다고 볼 수 있고, 함수 호출 = 만들어둔 함수를 사용한다 라고 할 수 있습니다.

 

1. 함수 선언하기

function functionName( argument1, argument2, ...) {
	//do something
    }

2. 함수 호출하기

functionName( value1, value2, ...);

함수 예제 살펴보기

1. 덧셈 함수

function add(x, y) {
  document.write(x+y); //document.write는 화면에 x+y결과를 표시해준다.
}

add(2, 3);
add(2, 7);

위를 보면 x와 y라는 두 개의 인수(argument)값을 받아 더해주는 add라는 이름의 함수를 선언했습니다.

그리고 add(2,3); 이런식으로 더해줄 두 값을 넣어주면 add함수를 통해 더한 결과를 확인할 수 있습니다.

 

2. 1부터 n까지 더한 값을 구해주는 함수

function sum(x) {
  var result = 0;
  for(var i = 0; i<=x; i++){
    result += i; //result = i + result와 같다.
  }
  document.write(result);
}

sum(10);

지난 시간에 배운 반복문을 이용하여 이런 식의 함수를 만들어볼 수도 있습니다.

한개의 값(x)을 받아서 1부터 해당 값까지 모두 더한 값을 출력하는 함수입니다.

10을 입력받으면 1부터 10까지 더한 값을 출력해주는 것입니다.


버튼 클릭 이벤트(Button Click Event)

 

자바스크립트에서 함수는 '버튼 클릭 이벤트를 발생'시킬 때도 자주 사용합니다.

예를 들어 사용자가 버튼을 클릭했을 때 "안녕?"이라는 alert창을 띄우고 싶다고 합시다. 이때 버튼을 누르는 사용자의  행위(action)를 이벤트(event)라고 합니다.  그리고 이 이벤트에 맞춰서 발생할 동작을 함수로 구현할 수 있습니다.

 

 

*이벤트(event) : 이벤트(event)는 사용자의 행위(action)를 의미합니다. 즉 사용자가 버튼을 누르거나 브라우저를 닫거나 하는 것들을 이벤트라고 볼 수 있습니다. 위의 예시에서는 버튼을 클릭하는 행위를 이벤트로 볼 수 있습니다.

 

*이벤트 타입(event type) : 이벤트의 종류를 의미합니다. 예를 들어 버튼을 클릭하는 이벤트라고 하면 click이 그 이벤트 타입입니다. 이밖에도 다양한 종류의 이벤트 타입이 존재합니다. [각주:2]

 

*이벤트 타겟(event target): 이벤트가 일어날 객체[각주:3]를 의미합니다. 예를 들어서 id가 A라는 버튼을 클릭했을 때 이벤트가 발생하도록 하고 싶은 거라면 A라는 버튼이 타겟이 되는 것입니다.

 

*이벤트 핸들러(event handler) = 이벤트 리스너(event listener) : 이벤트가 발생했을 때 동작하는 코드를 의미합니다. [각주:4]

 

 

1. 사용자가 버튼을 클릭했을 때 "안녕?"이라는 alert창을 띄우는 예제

  <button id = "btn1">버튼</button>

버튼생성과 같은 content나 구조에 대한 것은 html로 작업합니다.

codesandbox를 켜서 html파일에 위와 같이 적어주면 웹페이지에 버튼이 생성된 것을 확인할 수 있습니다.

document.getElementById("btn1").addEventListener('click',hello);

function hello(){
  alert("안녕?");
}

 버튼에 대해 '동작'하는 부분은 javascript가 담당합니다. 

 

 


2. 숫자 n을 입력받아 1부터 n까지 더한 결과를 출력하는 함수 만들기

 

이는 보다 심화된 예제입니다.

<input id="number" /> 
    <button id="btn1" onclick="addNum();">입력</button>
    <br />
    결과: <span id="output"></span>

먼저 html에는 숫자를 입력받을 창과 누르면 결과를 출력하도록 하는 버튼, 그리고 결과를 출력하는 부분 총 3가지가 필요합니다.

입력받는 것은 input태그[각주:5]를 이용하여 만들 수 있습니다. 그리고 버튼은 button태그를 이용하고, 결과를 띄워주기 위해 span태그를 이용해보도록 하겠습니다. (이때 div태그를 이용해도 괜찮습니다. 일단은 자세한 설명은 생략하고 사용하면서 어떤식으로 이용하는건지 익혀보도록 하겠습니다.) [각주:6]

document.getElementById("btn1").addEventListener("click", addNum);

function addNum() {
  var result = 0;
  var num = document.getElementById("number").value;
  for (var i = 1; i <= num; i++) {
    result += i; // result = result + i 와 같다.
  }

  document.getElementById("output").innerHTML = result;
}

 javascript파일에는 버튼을 클릭하는 이벤트가 발생했을 때 실행될 부분을 적어주어야합니다.

 

<코드설명>

 

*getElementById() : id를 이용하여 특정한 값을 가진 요소를 가져옵니다.

위에 코드를 보면 html파일의 button태그에 btn1이라는 id값을 주었습니다. 만약 버튼(button)이 여러개이고, 이중에서 하나의 버튼에 대해서만 특정 함수가 작동하길 바란다면 그 특정 버튼에 id값을 주어 다른 버튼들과 구분할 수 있습니다.

 

*addEventListener(): 이벤트 리스너는 특정 이벤트가 발생했을 대 그 처리를 담당하는 함수를 가리킵니다. addEventListener는 특정 이벤트 발생시 특정 함수를 실행시킵니다.

document.getElementById("btn1").addEventListener("이벤트종류", 함수이름);

우리가 작성할 이벤트리스너는 사용자가 버튼을 클릭했을 때 발생하므로 이벤트 종류는 click이고, 함수이름은 저는 addNum으로 설정했습니다.

 

*document.getElementbyId("아이디").innerHTML : 해당 id를 가진 객체 영역에 html코드를 삽입하는 소스입니다.

 

<div id = "test">김커피</div>
document.getElementById("test").innerHTML = "김라떼로 개명!";

위와 같은 예제를 직접 작성해보면 innerHTML이 어떤식으로 쓰이는지 알 수 있을겁니다 :)

 

 

  1. https://www.codingfactory.net/10386 함수선언,호출 방식에 대한 보다 자세한 블로그 포스팅입니다. 자세히 알고 싶은 분들은 참고하세요. [본문으로]
  2. 다양한 이벤트 타입을 포스팅해둔 게시물 링크입니다. https://abc1211.tistory.com/201 [본문으로]
  3. JavaScript변수 안에는 다양한 형태의 값을 저장할 수 있습니다. 어떤 경우에는 서로 연관된 값들을 하나로 묶어 저장할 필요가 있습니다.객체는 이 때 등장하는 개념입니다.객체 란 여러 속성을 하나의 변수에 저장할 수 있도록 해주는 데이터 형식입니다. [본문으로]
  4. 이벤트 핸들러 종류 : https://jdh5202.tistory.com/15 이벤트리스너 설명: http://tcpschool.com/javascript/js_event_eventListenerRegister [본문으로]
  5. https://coding-factory.tistory.com/24 [본문으로]
  6. div태그와 span태그의 차이점: https://m.blog.naver.com/PostView.nhn?blogId=javaking75&logNo=140160292268&proxyReferer=https%3A%2F%2Fwww.google.com%2F [본문으로]

2019/10/08 - [JavaScript/초보자를 위한 자바스크립트] - 초보자를 위한 자바스크립트 커리큘럼

2019/10/14 - [JavaScript/초보자를 위한 자바스크립트] - +자바스크립트 - html과 css를 가볍게 알아보자!

2019/10/02 - [JavaScript/초보자를 위한 자바스크립트] - 1. 초보자를 위한 '자바스크립트는 무엇인가?' (feat.프로그래밍을 배우고 싶다면)

2019/10/08 - [JavaScript/초보자를 위한 자바스크립트] - 2. 자바스크립트 변수(variable)와 자료형(data type)

2019/10/14 - [JavaScript/초보자를 위한 자바스크립트] - 3. 자바스크립트 - 비교연산자(Comparisons)와 조건문(Conditional operators)


배열(Array)

 

이전에 '변수'에 대해서 배웠을 때 변수란 데이터를 저장하는 공간이라고 했습니다.

1
var name = '김커피'
cs

 

이런식으로 name이라는 변수에 '김커피'란 문자데이터를 저장했습니다.

그렇다면 name이라는 변수 안에 2개 이상의 데이터를 넣을 순 없을까요?

바로 하나의 변수에 여러개의 데이터를 담을 수 있는 것이 '배열'입니다.

1
var name = ['김커피''김라떼''김모카']
cs

배열은 이런식으로 대괄호[]를 이용하여 생성할 수 있습니다.

 

1
alert(name);
cs

 

이런식으로 alert를 이용해서 name에 있는 값을 출력해보면 

name변수 안에 든 모든 값들이 출력되는 것을 볼 수 있습니다. 

그렇다면 만약 이중에서 '김라떼'라는 데이터 하나만을 출력해보고 싶으면 어떻게 할까요?

1
alert(name[1]);
cs

이렇게 하면 '김라떼'라는 값만 출력될 겁니다. 한번 따라해보세요.

이처럼 배열은 '인덱스(index)'를 갖고 있어서 이 인덱스를 통해서 배열 안의 여러 데이터 값들 중 특정 값만을 꺼내올 수 있습니다. 이 인덱스는 1번이 아닌, 0번부터 시작을 해서 첫번째 데이터는 name[0] 이렇게 써서 꺼내올 수 있습니다.

인덱스 번호는 1번이 아닌 0번부터 시작한다는 점을 주의해주세요!

 

이러한 배열은 반복문과 결합하여 자주 사용됩니다. 왜냐구요?

위의  name 배열에 현재는 3개의 데이터값만 들어있지만, 만약 100개 혹은 1000개 이런식의 많은 데이터가 들어있다고 칩시다. 그러면 모든 데이터를 하나씩 출력한다고 했을 때 일일이 alert(name[0]); alert(name[1]); alert(name[2]); .....이런식으로 쳐서 출력해야할까요? 많은 데이터가 있을때 엄청 힘들고 노가다 작업이겠죠?

 

그러면 0번 인덱스부터 99번 인덱스까지 하나씩 출력해줘~ 라고 할 수 있으면 얼마나 편할까요?

이처럼 반복되는 노가다 작업을 줄여주고, 효율적으로 처리할 수 있게 하는 것이 바로 '반복문'입니다.

반복문은 이와 같은 반복되는 작업을 편리하게 처리해줍니다. 그럼 이러한 반복문에 대해 배워볼까요?

 


반복문(loop)

반복문은 반복되는 작업을 처리해주는 것으로 여러가지 반복문 문법이 있습니다. 사용하는 방식이 다르므로 상황에 따라 더 적합한 것을 선택하여 사용하시면 됩니다. 저희는 대표적인 반복문인 while문과 for문에 대해 배워보도록 하겠습니다.

 

while 반복문

while(조건) {
	반복되어 실행될 코드
    }

while반복문은 위와 같이 구성됩니다. 조건이 'true(참)'일 때 '반복되어 실행될 코드'가 실행됩니다.

그리고 조건이 false(거짓)이 되면 반복문을 종료합니다. 

 

alert를 통해 값을 하나씩 순차적으로 출력하고 싶을 때 어떻게 해야할까요?

1
2
3
4
5
6
7
8
9
10
11
12
13
 var name = [
    "김커피",
    "김라떼",
    "김모카",
    "김아메",
    "김뚜비"
  ];
 
  var i = 0;
  while (i < 5) {
    alert(i+"번 학생은"+name[i]+"입니다.");
    i = i + 1//i++나 i+=1 이라고 해도 된다.
  }
cs

while반복문을 이용하여 위와 같이 코드를 짤 수 있습니다. 

이제 위 코드를 통해 while반복문에 대해 이해해보도록 하겠습니다.

 

먼저 i 의 값은 0입니다. while문 안에 든 조건문은 i < 5 입니다. i 는 0보다 작으므로 i < 5 (i는 5보다 작다) 는 true입니다. 그러므로 while문 내부의 코드가 실행됩니다. alert를 통해 "0번 학생은 김커피입니다"를 출력하고, i의 값을 하나 증가시켜줍니다. 

i = i + 1; //i에 1을 더하겠다.
i++; //i의 값을 1 증가시키겠다.
i += 1; // i = i + 1 을 줄여서 쓴 것으로 같은 의미이다.

이때 i의 값이 1증가하는 것은 위와 같이 다양하게 표현될 수 있습니다. 주로 1의 값을 증가시키는 경우

i++ 을 많이 사용합니다. 만약 i의 값을 1 감소시키고 싶으면 i-- 이라고 쓸 수도 있습니다.1

 

반복문의 실행과정

이처럼 i 가 5가 되었을 때는 i<5라는 조건을 만족시키지 못하고 false를 반환하면서 조건이 '거짓(false)'이 되어 while문을 더이상 실행시키지 않고 반복문을 종료하는 것입니다.

이처럼 i=0이고 i<5라는 조건을 주어 while반복문을 실행하였을때 결과적으로 총 5번이 실행되어 배열에 있는 모든 값을 한번씩 출력하고 반복문을 안전히 종료할 수 있었습니다.

 

만약 반복문이 존재하지 않는다면, 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
var name = [
    "김커피",
    "김라떼",
    "김모카",
    "김아메",
    "김뚜비"
  ];
 
 
alert("0번 학생은"+name[0+"입니다.");
alert("1번 학생은"+name[1+"입니다.");
alert("2번 학생은"+name[2+"입니다.");
alert("3번 학생은"+name[3+"입니다.");
alert("4번 학생은"+name[4+"입니다.");
  
cs
 

위와 같이 일일이 여러번 적어야하기 때문에 번거롭고, 코드 길이도 길어지게 되는 불편함이 있겠죠.


for반복문

1
2
3
for(초기화; 조건; 반복이 될때마다 실행되는 코드){
    반복해서 실행될 코드
    }
cs

for반복문은 위와 같이 씁니다.

아래 예시를 통해 살펴보도록 하겠습니다.

1
2
3
4
5
var fruit = ["딸기""사과""포도""수박""체리"];
 
  for (var i = 0; i < 5; i++) {
    alert(i + "번째 과일은" + fruit[i] + "입니다.");
  }
cs

위 코드의 3번째 줄을 보면 

i라는 변수의 값은 0으로 초기화하고, 조건은 i < 5 이고, 반복문이 한번 실행될때마다 i의 값을 1씩 증가시켜주겠다.

는 의미입니다. while문으로 바꿔서 써보면

 

1
2
3
4
5
6
7
var i = 0;
 
while(i<5){
 
i++;
 
}
cs

 

이 되겠습니다.


while문과 for문을 둘다 사용할 수 있는 경우도 있지만, 주로 while문은 정확히 몇번 반복해야할지 모를때 사용합니다. 그리고 for문은 정확하게 반복횟수를 지정할 수 있기 때문에 반복횟수를 알고 있을때 사용하는 편입니다.

 

이러한 반복문에서 주의할 점은 조건이 true일 경우엔 계속해서 반복한다는 것입니다. 그래서 반복문을 사용할때는 꼭 반복문을 빠져나올 수 있는 부분을 작성해야합니다. 앞서 진행한 예제를 보면 i값이 1씩 증가하도록 하여 일정 횟수 이후에는 조건문이 false를 반환하여 반복문을 종료할 수 있도록 하였습니다. 만약 이러한 부분이 작성되어있지 않으면 반복문은 종료하지 않고 계속해서 반복하여 프로그램은 종료되지 않고 무한루프에 빠지게 됩니다.

 

코드

-

퀴즈

1. 반복문을 사용하여 구구단을 출력해보세요.

(기존에는 alert를 이용하여 출력을 했으나 이번에는 console.log()를 이용해서 콘솔창에 출력을 하세요.)

콘솔창은 codesandbox에서 오른쪽 실행결과창 아래에 console이라고 적힌 부분을 클릭하면 볼 수 있습니다.

위와 같은 식으로 구구단이 콘솔창에 9단까지 출력되도록 하세요.

 

더보기

<힌트>

 

구구단은 1단부터 9단까지 입니다.

1단은 1에 1부터 9까지를 곱합니다. 그러므로 총 9번이 반복됩니다. (횟수가 정해져있으니 for문을 쓰는게 좋습니다) 2단 역시 2에 1부터 9까지를 곱합니다. 2단 역시 9번 반복됩니다.

이런식으로 9단까지하면 각 단마다 9번씩 곱셈을 하기 때문에 총 81번 반복하게 됩니다.

 

1. 앞서 곱셈은 * 연산자를 통해 한다고 배웠습니다.

2. 두 값을 곱해야하므로 2개의 변수가 필요합니다. 

3. 반복문 안에 반복문을 넣어서 쓸 수 있습니다. 이런 것을 '중첩반복문'이라고 합니다.

 

2. 아래 사진과 같이 콘솔창에 출력하도록 반복문을 작성해보세요.

*은 문자로 "*"로 쓰면 됩니다.

2019/10/08 - [JavaScript/초보자를 위한 자바스크립트] - 초보자를 위한 자바스크립트 커리큘럼

2019/10/02 - [JavaScript/초보자를 위한 자바스크립트] - 1. 초보자를 위한 '자바스크립트는 무엇인가?' (feat.프로그래밍을 배우고 싶다면)

2019/10/08 - [JavaScript/초보자를 위한 자바스크립트] - 2. 자바스크립트 변수(variable)와 자료형(data type)

2019/10/14 - [JavaScript/초보자를 위한 자바스크립트] - 3. 자바스크립트 - 비교연산자(Comparisons)와 조건문(Conditional operators)

2019/10/14 - [JavaScript/초보자를 위한 자바스크립트] - +자바스크립트 - html과 css를 가볍게 알아보자!

 


이번에는 지난 시간에 배웠던 html, css, 그리고 비교연산자와 조건문을 활용하여

"자바스크립트(JavaScript)로 자판기 만들기" 예시를 진행해보도록 하겠습니다.

이런 "실습예제" 포스팅은 어렵다고 느껴지시면 이후 개념진도를 다 나간 후에 몰아보셔도 좋습니다.

궁금한 점은 언제든지 댓글로 남겨주시면 답변드리겠습니다.


문제

 

*먼저 자판기는 아래와 같은 형식으로 구성이 될 것입니다.*

자판기 예시 이미지

1. 판매하는 제품 : 옥수수수염차(1000원) / 커피(700원) / 물 (500원)

2. 넣을 수 있는 동전과 지폐: 100원 / 500원 / 1000원

3. 현재 넣은 금액 표시하기 (돈 100원을 넣었으면 '현재 금액: 100원' 이라고 표시해야한다)

4. 돈을 넣었을때 구매할 수 있는 경우 구매가능한 제품명을 파란색으로 표시하고, 구매할 수 없는 경우 빨간색으로 표시한다.

5. 제품버튼을 눌러 구매했을 경우 해당 구매한 제품의 금액만큼 '현재 금액'이 줄어야한다. (옥수수수염차를 구매했을 경우 1000원이 줄어야한다)

 

좀더 자세히 설명

 

자세한 설명

실습코드

 

 

목차

2019/10/08 - [JavaScript/초보자를 위한 자바스크립트] - 초보자를 위한 자바스크립트 커리큘럼

2019/10/02 - [JavaScript/초보자를 위한 자바스크립트] - 1. 초보자를 위한 '자바스크립트는 무엇인가?' (feat.프로그래밍을 배우고 싶다면)

2019/10/08 - [JavaScript/초보자를 위한 자바스크립트] - 2. 자바스크립트 변수(variable)와 자료형(data type)

2019/10/14 - [JavaScript/초보자를 위한 자바스크립트] - 3. 자바스크립트 - 비교연산자(Comparisons)와 조건문(Conditional operators)

 

 


지금까지 저희는 codesandbox에서 index.js 파일 [각주:1]만 이용해서 공부했습니다. 

지난 포스팅 내용

맨 첫 시간에 웹페이지는 html과 css, JavaScript 이 3가지로 구성되어있다고 했습니다. 그러나 지금까지 저희가 배운 건 오로지 자바스크립트고 html과 css에 대해서는 배우지 않았습니다. 이 3가지는 긴밀히 연결되어 웹페이지를 구성하므로 이번 시간엔 간단하게 html과 css에 대해서도 배워보도록 하겠습니다.

 

html

먼저 html이란 웹의 뼈대(구조)를 담당합니다. html은 한번쯤 본 적이 있을텐데요,

이런식으로 구성이 되어있습니다. 

<head>안에 들어가는 내용은 우리가 보는 웹페이지 화면에 직접적으로 보여지지는 않지만 웹브라우저가 알아야할 주요한 정보들이 들어있습니다. 그리고 <body>안에는 웹페이지 화면에 직접 출력되는 내용들이 들어있습니다.

 

이러한 <> 것들을 '태그'라고 부릅니다. 이러한 태그들의 종류는 다양합니다. [각주:2]

자주 쓰이는 것들 중 하나로 버튼 태그가 있습니다. <button></button>이런식으로 쓰면 버튼이 생성됩니다.

 

그럼 몇가지 정말 자주 쓰이는 기본적인 태그들을 직접 타이핑하면서 공부해볼까요?

평소처럼 codesandbox에 들어가서 vanilla sandbox를 생성해주시고, index.js에 들어가서 불필요한 부분을 삭제 후 index.html에 들어가서 아래와 같이 타이핑 해봅니다. 오른쪽에 있는 화면은 실제 웹브라우저에 출력되는 모습입니다.

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
32
33
34
35
<!DOCTYPE html>
<html>
  <head>
    <title>예시</title>
    <meta charset="UTF-8" />
  </head>
 
  <body>
    <div id="app"></div>
    <h1>제목입니다</h1>
    <h2>소제목입니다.</h2>
    <button>버튼</button>
    <ul>
      <li>목차1</li>
      <li>목차2</li>
      <li>목차3</li>
    </ul>
    <p>문단에 여러가지 내용들~</p>
    <p>
      문단에 여러가지 내용들~문단에 여러가지 내용들~문단에 여러가지
      내용들~문단에 여러가지 내용들~문단에 여러가지 내용들~문단에 여러가지
      내용들~문단에 여러가지 내용들~문단에 여러가지 내용들~
    </p>
 
    <!--주석입니다. 코드에 아무런 영향을 미치지 않고 코드에 대한 설명을 적을 수 있습니다.-->
 
    <a href="https://kim-coffee.tistory.com/">김커피 블로그주소</a>
    <br />
    <img
      style="width: 400px"
      src="https://static.independent.co.uk/s3fs-public/thumbnails/image/2018/04/15/16/china-coffee-cup.jpg?w968h681"
    />
    <script src="src/index.js"></script>
  </body>
</html>
cs

 

<주요 태그 설명>

<h1> 

제목. <h2>...<h6>까지 있다. 점점 폰트크기가 작아진다.
<button> 버튼
<ul> <li> 항목 나열
<p> 문단
<a> 링크 (href = "여기에 연결할 주소 넣으면 된다")
<br> 엔터키와 같은 역할을 한다. 한줄 띄기.
<img> 이미지 삽입 태그. (src = "여기에 이미지 주소를 넣으면 된다")

주요태그 설명을 한번 읽어보시고 직접 코드를 치면서 웹브라우저 화면에 어떻게 출력되는지를 살펴보세요. 하나하나 직접 타이핑해보는 편이 더 이해가 빠를 것 같습니다.

 


CSS

 

css는 웹페이지에서 디자인을 담당하는 부분입니다.  이런 css를 통해 폰트의 색상을 바꾸거나 가운데정렬을 하거나 하는 등 다양한 디자인적인 부분을 꾸밀 수 있습니다. css를 html에 적용하는 방법은 몇가지가 있습니다. 

 

1. html에 <style>태그를 삽입

html파일에 <style>태그를 삽입하여 <style></style>태그 내부에 css를 적어주면 html파일에 css를 통한 디자인이 적용됩니다. 

 

2. css파일에 작성

codesandbox에 보시면 style.css파일이 있습니다. 이 파일 내에 css코드를 적어주면 html파일에 css가 적용됩니다.

 

h1 {
  color: brown;
}

css코드는 이런식으로 생겼습니다. 우리가 위에 적은 html코드에 css를 적용해줄건데요. <h1>태그에 폰트컬러를 브라운컬러로 바꾸고 싶으면 위와 같이 적어주면 됩니다. red, blue 등등 다양한 색상을 쓸 수 있습니다. 

 

css구성

css는 이와같이 선택자(selector), 속성(property), 값(value)으로 구성되어있습니다.

 


CodeSandbox 코드

 

 

앞서 공부한 예시들을 적어놓은 codesandbox입니다. 실습을 하실 때 위 코드를 참고하셔서 자신의 코드가 맞게 쓰여졌는지, 에러가 발생한다면 어느 부분이 잘못되었는지 비교하면서 봐주세요.

모르는 점은 댓글로 질문을 남겨주시면 답변 드리겠습니다 :)

 

codesandbox의 share버튼 클릭했을 때 뜨는 창-editor url복사

본인의 codesandbox에서 에러가 발생했을 경우 codesandbox 오른쪽 상단에 있는 share버튼을 클릭하셔서 url을 복사해서 댓글로 남겨주시면 제가 코드를 직접 확인하고 답변을 달아드릴 수 있습니다.


*참고자료: 

http://www.homejjang.com/03/html_structure.php

http://egloos.zum.com/fundoodle/v/3131696

https://www.codingfactory.net/10187

  1. js가 JavaScript파일을 의미합니다 [본문으로]
  2. 다양한 html태그들이 정리되어있는 포스팅입니다. 참고하세요. http://egloos.zum.com/fundoodle/v/3131696 [본문으로]
  1. [JavaScript/초보자를 위한 자바스크립트] - 초보자를 위한 자바스크립트 커리큘럼
  2. [JavaScript/초보자를 위한 자바스크립트] - 1. 초보자를 위한 '자바스크립트는 무엇인가?' (feat.프로그래밍을 배우고 싶다면)
  3. [JavaScript/초보자를 위한 자바스크립트] - 2. 자바스크립트 변수(variable)와 자료형(data type)

지난시간에 자바스크립트(JavaScript) 변수와 자료형을 공부했던 것에 이어서 이번에는 비교연산자와 조건문에 대해 공부해보도록 하겠습니다. '초보자를 위한 자바스크립트'에 있는 내용들은 정말 basic하고 모든 프로그래밍 언어에 존재하는 기본 문법들입니다.

 

비교연산자

 

비교연산자란 주어진 값들이 서로 같은지, 다른지, 큰지, 작은지 비교해주는 연산을 수행합니다.

비교연산자를 통해 연산된 결과값으로는 true 또는 false 즉 – 참이냐 거짓이냐 이 2가지만 존재하게 됩니다. 앞서 자료형을 학습했는데, 거기서 boolean형을 언급한 적이 있습니다. 이러한 true 또는 false의 값을 갖게 되는 것이 바로 boolean형 데이터입니다.

 

23 < 4

 true인가요, false인가요?

아래에 23 < 4 라고 입력해서 직접 확인해보세요.

 

4는 23보다 작은 숫자이므로 결과는 false가 됩니다.

 

 ==  변수의 데이터 타입과 상관없이 값이 같으면 참이다.
 ===  변수의 데이터 타입까지 고려하여 값이 같으면 참이다.
 !=  변수의 데이터 타입과 상관없이 값이 다르면 참이다.
 !==  변수의 데이터 타입까지 고려하여 값이 다르면 참이다.
 >  변수의 값이 더 크면 참이다. (초과)
 <  변수의 값이 더 작으면 참이다. (미달)
 >=  변수의 값이 더 크거나 같으면 참이다. (이상)
 <=  변수의 값이 더 작거나 같으면 참이다. (이하)

비교연산자의 종류는 위와 같습니다. 그런데 여기서 ==와 ===이 어떻게 다른지 예시를 통해 살펴볼까요?

*그전에 한가지 주의할 점은 = 과 == 은 다른 종류의 연산자라는 것입니다.

=은 대입연산자로 우항의 값을 좌황에 대입해주겠다-라는 뜻이고, ==는 좌항과 우항의 값을 비교하겠다는 비교연산자입니다.

 

 

저번 시간에 언급했듯이 "문자열"은 따옴표로 둘러싸서 표기해야한다고 했습니다.

하지만 숫자는 따옴표가 필요하지 않았죠.

기억이 나지 않는다면 저번시간 내용을 복습하고 오세요 ^ㅇ^

 

1 이건 숫자 데이터 타입입니다.

'1' 이건 문자 데이터 타입입니다.

 

 데이터 타입이 다르다는 의미입니다. 1은 숫자이고, '1'은 문자이니까요. 

1 == '1' 은 'true'입니다.

1 === '1' 은 false입니다.

 

이제 좀 이해가 되셨나요? 

 

==와 ===가 '같은지'를 따져주는 연산자라면, != 와 !==는 반대의 의미를 갖고 있습니다. 이 연산자는 '다를 경우에' 참(true)을 반환합니다. 위에서 1 === '1'은 false라고 했습니다. 왜냐하면 1은 숫자이고, '1'은 문자여서 자료형이 다르기 때문이었습니다.

 

그렇다면

1 !== '1'

은 무슨 결과값이 나와야할까요? 한번 맞춰보세요!

 

네, 정답은~~~ true(참)입니다. 왜냐하면 1과 '1'은 다르기 때문입니다.

===는 자료형까지 같은 경우 참을 반환하고, !==은 다를 경우에 참을 반환합니다.

 

그리고 5 <= 5 은 참일까요, 거짓일까요?

네, 참입니다. 왜냐하면 왼쪽의 값이 오른쪽값보다 작거나 같으면 '참'을 반환하기 때문입니다.

5 <= 6 또한 참이라고 할 수 있습니다! 

 

이 비교연산자 문제에 대해선 제가 퀴즈도 많이 낼테니 문제를 풀면서 달달달 헷갈리지 않게 익혀주세요^^


조건문

이번엔 이 비교연산자를 활용할 수 있는 '조건문'을 배워보도록 하겠습니다.

조건문은 주어진 조건에 따라서 애플리케이션을 다르게 동작하도록 하는 것 입니다.

if조건문

if ~ else if ~ else 이런식으로 구성이 되어있습니다.

if(조건1) → 조건1일 경우 실행

else if(조건2) → 조건2일 경우 실행

else → 조건1, 조건2 둘다 해당되지 않은 나머지 경우에 실행

 

예를 들어서 우리가 성적을 계산할 때 이용할 수 있습니다.

앞서 배운 '비교연산자'를 이용하여 내 성적과 기준점수(90점)을 비교합니다. 내 성적 78점은 90점보다 작기 때문에 조건 "내성적 >= 90"을 만족하지 못하고 조건은 false를 반환합니다. 이처럼 조건이 false인 경우는 해당 조건에 만족할 경우에만 실행되는 "점수 A주기"를 실행하지 않습니다.

90점 이상은 A, 71~89점은 B, 70점 이하로는 모두 C 라고 합시다. 그럴 경우 아래와 같은 코드를 작성할 수 있습니다. scroe엔 여러분이 바라는 점수를 적어보세요. 여러분의 점수는 몇등급 인가요?

var score = 78; //내 점수
var grade;//내 성적

if(score >= 90) grade = 'A'; //90점 이상은 A

else if(score >= 71 && score <= 89) grade = 'B'; // 71~89점은 B

else grade = 'C'; //70점 이하는 C

alert("점수는 " + grade);

여기서 추가적인 부분을 설명하자면 &&은 and를 의미 [footname] 이와 같은걸 '논리연산자'라고 합니다. 조금 더 자세히 알고 싶으시다면 https://m.blog.naver.com/PostView.nhn?blogId=smilebanner88&logNo=220729516010&proxyReferer=https%3A%2F%2Fwww.google.com%2F 글을 참고해주세요. [/footname] 합니다. score >= 71 (점수가 71점이상) 이면서 score <= 89 (점수가 89점 이하) 일 경우에는 true를 반환합니다. 그러니까 즉 2가지 조건에 '모두' 만족할 경우에만 참인 것입니다. 

 

이런식으로 조건문은

if(조건) → {조건이 '참'일 경우 실행할 내용 } 

 

이런식으로 쓰시면 됩니다. 그리고 이 조건문 안에 들어가는 '조건'은 반환값이 ture 또는 false여야하기 때문에 위에서 우리가 공부한 '비교연산자'가 쓰이는 것입니다.

 

만약 처음부터 조건 자체가 'false'(거짓)이라면 아무것도 실행되지 않습니다.

우리가 위에서 했던 예시를 바탕으로 해보자면

if(23 < 4){
alert('실행될 내용');
}

이렇게 입력해보시면 아마 아무것도 실행되지 않을 겁니다. 이유는 23<4는 false이기 때문이죠. 이처럼 조건문은 조건이 거짓일 경우에는 작동하지 않습니다.

*퀴즈는 모바일에선 지원되지 않습니다.

3과 비교연산자와 조건문 퀴즈

  • 30 <= 30 은 참인가 거짓인가?

거짓(false)
참(true)

  • '2' === 2 는 참인가 거짓인가?

거짓(false)
참(true)

  • '2' !== 2 는 참인가 거짓인가?

거짓(false)
참(true)
 

*이전글 :

0. 초보자를 위한 자바스크립트 커리큘럼

1. 초보자를 위한 '자바스크립트는 무엇인가?' (feat.프로그래밍을 배우고 싶다면)

 

 

이번 시간에는 자바스크립트(JavaScript)의 변수와 자료형에 대해서 공부하는 시간을 가져보도록 하겠습니다.

 

먼저 변수와 자료형은 모든 프로그래밍 언어에서 존재하는 아주 기초적인 부분입니다.

외국어 공부할 때도 기본적인 뼈대가 되는 문법이 존재하는 것과 마찬가지입니다. 


 

0. 실습을 위한 준비작업

별도의 개발 프로그램을 설치하는 과정 없이 그냥 codesandbox 웹사이트(https://codesandbox.io)를 이용하도록 하겠습니다.

1. codesandbox에 회원가입을 하고 로그인을 합니다. 그러면 바로 dashboard창이 뜰텐데 그렇지 않은 분들은 우측 하단에서 프로필 이미지를 누르고 dashboard를 클릭합니다.

2. Dashboard에서 create sandbox를 클릭합니다.

3. vanila 를 클릭합니다.

4. 빨간색으로 표시한 부분은 전부 지워주세요. 

이제 실습을 위한 준비가 완료되었습니다!


변수(Variable)란?

변수는 영어로 variable이라고 하며, 쉽게 얘기해서 "데이터를 저장하는 공간"이라고 생각하시면 됩니다.

변수는 '변하는 수'라는 뜻입니다. 왜냐면 변수 안에 든 데이터들은 수시로 바뀔 수 있기 때문입니다. 예를 들어서 제가 이 블로그 포스팅의 제목을 수정할 수도 있고, 글 내용을 수정할 수도 있는 것처럼 말이죠. 변수를 선언할 땐
var 변수명 = 변수 안에 넣을 데이터 값;
이런식으로 쓰시면 됩니다. var은 변수를 선언하겠다는 것을 의미하며 생략해도 되지만 의미가 있기 때문에 일단 꼭 써주도록 합시다.


자료형(Data Type)이란?

데이터의 종류를 나타내는 것 입니다. 

 

 자바스크립트에는 이렇게 5가지의 데이터 타입이 있습니다.

  • string 문자열
  • number 숫자
  • boolean 참, 거짓(true, false)값 [각주:1]
이게 의미하는 건 그냥 이런 종류의 데이터들이 변수에 들어갈 수 있다는 것 입니다.

일단은 이렇게만 알아두시고 object(객체)와 function(함수)은 이후에 배워봅시다!


2. 실습

 

 

alert("hi");​

위 코드를 codesandbox에 적으시면 알람 창이 뜰 것입니다. alert는 그냥 그런 용도로 알아두시면 됩니다.

※hi와 같은 문자를 입력할 때는 꼭 "" 따옴표를 붙여주시고, 문장에 마침표를 찍듯 코드의 마지막에는 ; 를 붙여주시기 바랍니다.

var name = "김커피";

이는 name이라는 변수를 선언하고, 그 변수 안에 "김커피"라는 문자 데이터를 넣어줬습니다.

현재 name이라는 변수 안에는 "김커피"라는 데이터가 들어있는 것 입니다.

 

var name = "김커피";
alert(name);

이렇게 적어주면 이번엔 알람창 안에 김커피 라는 값이 뜨죠?

이유는 name이라는 변수 안에 "김커피"라는 데이터가 들어있기 때문입니다.

var name = "김커피";
name = "김커피2";
alert(name);

이런식으로 name변수 에 있는 데이터를 수정할 수 있습니다.

알람창에는 "김커피"가 아니라 "김커피2"가 뜰 것입니다. 왜냐면 name이라는 변수 안에 데이터값이 김커피->김커피2로 변화했기 때문입니다. 이처럼 변수 안에 있는 값은 바꿀 수 있습니다.

alert("김커피");

만약 이런식으로 썼다면 알람창 안의 메세지를 계속해서 지우고 다시  쓰는 작업을 반복해야할 것입니다.

그러나 name이라는 변수를 선언하고 그 안에 데이터를 넣어줬다면, 그냥 name = " "; 이런식으로 name안에 값을 바꿔서 넣어주면 됩니다.  

 

Edit 2j2go

*이를 통해 실제 위의 코드 결과값을 확인해볼 수 있습니다. 

 


3. 응용(사칙연산)

1
2
3
4
5
6
7
8
9
10
11
12
var age = 18;
//18+2 = 20
age = age + 2// age += 2; 와 같이 쓸 수도 있다.
//20-5 = 15
age = age - 5// age -= 5; 와 같이 쓸 수도 있다.
//15*10 = 150
age = age * 10// age *= 10 곱셈
//150/5= 30
age = age/5// age /= 4 나눗셈
 
alert(age);
 
cs

이번엔 age라는 변수에 18이라는 숫자를 넣었습니다. 문자와 다르게 숫자는 ""따옴표가 필요하지 않습니다.

덧셈, 뺄셈, 곱셈, 나눗셈 이와 같은 사칙연산은 + - * / 기호를 통해 할 수 있고 위의 예제와 같이 작성하실 수 있습니다.

참고로 // 은 주석을 표시하는 것으로 코드에는 영향을 미치지 않고 '이해를 돕도록 코드를 설명' 할 때 쓰이는 것입니다. 

 

실제로 위 코드를 따라서 차분히 쳐보시고 알람창에 정말로 30이 뜨는지 꼭 확인해보세요!


4. 퀴즈

 

*퀴즈는 모바일버전은 지원하지 않습니다.

2과.변수와 자료형 퀴즈

  • boolean자료형이 가질 수 있는 값은?
숫자
참/거짓
문자
정수

  • 나눗셈을 하려면 어떤 기호를 써야하는가?
+
-
*
/

 

 

 

 

 

 

  1. 이 boolean형에 대해서는 다음시간에 비교연산자를 공부할때 자세히 알 수 있습니다. [본문으로]

 

<초보자를 위한 자바스크립트 커리큘럼>

 

1.An introduction of JavaScript & What can you do with JavaScript?

2.Variables & Data types

3.Comparisons & Conditional operators (vending machine example)

4.Array and Loops (calendar example)

5.Functions (calculator example)

6.Objects (to-do-list example)

7.Guideline for Next Step!

...더보기

1. 자바스크립트에 대한 아주 간략한 소개 & 자바스크립트를 통해 무엇을 할 수 있는지 소개 =동기부여

2. 자료형과 변수

3. 비교문과 조건문 - 이를 통해 간단한 자판기를 만들어봅니다

4. 배열과 반복문 - 이를 통해 달력을 만들 수 있습니다

5. 함수 - 이를 통해 계산기를 만들어봅시다

6. 객체 - to do list를 만들어봅시다

 

 

*교육대상 : 프로그래밍에 관심은 있으나 프로그래밍에 대한 지식이 없는 중고등학생 이상의 학습자들 

*교육목표 : 자바스크립트(JavaScript)가 무엇인지 이해하고, 간단한 예제와 함께 자바스크립트에 대한 기본적인 문법 지식을 이해한다. (beginner수준이라고 보시면 됩니다)

 

 


초보자를 위한 자바스크립트 카테고리에 업로드될 콘텐츠들은

위와 같은 커리큘럼으로 진행될 예정입니다.

 

*마지막으로 모든 교육 콘텐츠 업로드 이후 이 교육콘텐츠를 통해 목표에 달성한 학습자들을 위해 다음 단계의 학습 가이드라인(다음으로 무엇을 공부할지 제공할 예정입니다. 이는 beginner수준에서 더 나아가 advanced 수준의 학습을 원하는 학습자들에게 도움이 될 것입니다.

이 글은 프로그래밍에 관심은 있으나 프로그래밍이 뭔지, 왜 배워야하는지 구체적인 목표가 없는 고등학생 이상을 대상으로 한 포스팅입니다. 이 글을 통해서 프로그래밍 언어 중 하나인 JavaScript가 무엇인지, 그리고 프로그래밍을 공부함으로써 무엇을 얻을 수 있는지에 대한 개념을 최대한 쉽게 설명하고자 합니다. 


0. 왜 프로그래밍을 배워야 하는가?

먼저 우리는 왜 프로그래밍 언어를 배워야할까요? 이제는 프로그래밍이 의무교육이 될 정도로 중요시되고 있는데 그저 '중요하고 다들 배우려한다'정도로 알고 있을 뿐 그 이유를 명확히 아는 사람들은 많지 않은 것 같습니다. 특히 개발자를 꿈꾸지 않는 사람이라면 더더욱 왜 공부해야하는지 그 이유가 불명확해집니다.

 

구글검색결과

 

  • 선택할 수 있는 직업의 폭이 넓어진다.
  • 문제해결능력을 기를 수 있다.
  • 아이디어를 현실화할 수 있다.
  • 이제는 코딩을 모르면 도태될 수 있다.
출처: https://taegon.kim/archives/9716

여러 인터넷자료들과 제 경험을 비추어보았을 때 가장 와닿고 현실적인 이유들을 꼽아보았습니다.

이제는 IT직군 뿐만 아니라 기타 산업군에서도 코딩능력을 필요로 하고 있습니다. 그렇기 때문에 프로그래밍을 할 줄 알면 선택할 수 있는 직업의 폭이 넓어집니다.  혹은 코딩 능력을 통해 다른 지원자들과의 차별점을 만들 수 있습니다.

또한 코딩을 통해 간단한 프로그램을 개발하여 반복적인 업무를 간편하게 단순화하고, 추상적인 아이디어를 현실화할 수 있으며, 코딩을 통해 문제해결능력을 키울 수도 있습니다.

게다가 이제는 코딩이 의무교육이 된 때입니다. (얼마나 실효성이 있을진 모르겠지만;) 지금은 막 의무교육이 도입된 시점이라 체감할 수 없겠지만, 앞으로는 코딩을 모르면 도태되는 때가 올 수도 있지 않을까 하는 염려도 있습니다.

 

1. 자바스크립트로 선정한 이유

 

  • 프로그램을 설치하는 사전작업이 필요 없어서

  • 직관적으로 실행결과를 눈으로 볼 수 있어서
  • 비교적 다른 프로그래밍언어에 비해 배우기 쉬워서

일단 기초적인 수준의 *프론트엔드 개발을 공부하는 데 있어서 자바스크립트는 별도의 프로그램을 설치하여 복잡하게 개발환경을 구축할 필요 없습니다. codesandbox나 codepen과 같이 브라우저에서 작동하는 에디터들을 사용하여 간편하게 자바스크립트 프로그래밍을 할 수 있다는 장점이 있습니다.

 

*프론트엔드 개발: 쉽게 말하면 사용자들의 눈에 보이는 웹화면을 개발하는 것입니다.

*백엔드 개발: 반대되는 개념으로 백엔드 개발이 있고, 사용자들의 눈에 보이지 않는 뒷부분- 서버개발 등을 의미합니다.

 

또한 실행결과를 웹브라우저를 통해 볼 수 있어서 바로 바로 실행결과를 직관적으로 확인할 수 있다는 장점이 있습니다. 그리고 웹 브라우저에서 동작하다보니 운영체제의 제한을 받지 않습니다. 

 

마지막으로 다른 프로그래밍 언어들에 비해 비교적 진입장벽이 낮고 배우기 쉽다는 장점이 있습니다. 보통 프로그래밍 언어를 공부할 때 C언어를 시작으로 하는 경우가 많은데 C언어는 비교적 어려운 언어라서 초반부터 너무 어려움을 느끼고 쉽게 공부를 포기할 수 있다는 단점이 있다고 생각합니다.

 

덧붙이자면 자바스크립트는 수요도 많은 편이라 전망 있는 프로그래밍 언어로 볼 수 있습니다.

 

2. 자바스크립트란?

 


자바스크립트
(영어: JavaScript)는 객체 기반 스크립트 프로그래밍 언어이다. 이 언어는 웹 브라우저 내에서 주로 사용하며, 다른 응용 프로그램의 내장 객체에도 접근할 수 있는 기능을 가지고 있다. 또한 Node.js와 같은 런타임 환경과 같이 서버 사이드 네트워크 프로그래밍에도 사용되고 있다. (출처: 위키백과)

 

위는 위키백과에 나와있는 자바스크립트에 대한 설명입니다. 여기서부터 낯선 단어들이 등장하죠.ㅋㅋ 객체 기반? 스크립트 프로그래밍 언어? 서버사이드 네트워크 프로그래밍? 벌써부터 뭔가가 어려워보입니다. 그냥 쉽고 간단하게 설명하도록 하겠습니다.

 

자바스크립트는 우리가 사용하는 웹브라우저 (크롬, 인터넷 익스플로러러 등등)에서 동작하는 프로그래밍언어입니다.

 

웹페이지의 구성요소

우리가 방문하는 모든 웹페이지들은 모두 html, css, 그리고 JavaScript 이렇게 3가지로 구성되어있습니다.

먼저 html은 웹의 '내용들'입니다. 예를 들면 제가 이렇게 작성하고 있는 글의 내용, 제목 등이 되겠습니다. 

그리고 CSS는 이런 html이 보여주는 콘텐츠를 보기 좋게 예쁘게 꾸며주는 역할을 담당합니다. 예를 들면 글의 폰트나 색상과 같은 '디자인적인 요소를 담당'하죠.

마지막으로 JavaScript'동작'을 담당합니다. 예를 들면 html로 버튼을 하나 만들어 넣고, css로 그 버튼을 예쁘게 디자인합니다. 그리고 그 버튼을 클릭해서 발생하는 동작은 javascript가 담당하는 것입니다.

 

3. 자바스크립트로 무엇을 할 수 있는가?

 

그렇다면 자바스크립트를 배워서 우리는 무엇을 할 수 있을까요?

https://www.grandcircus.co/blog/10-things-you-can-build-with-javascript/

 

10 Things You Can Build with JavaScript - Grand Circus - Tech Training

JavaScript is the most widely used programming language in the world. But what does it build? Learn about 10 things you can build with JavaScript.

www.grandcircus.co

위 글을 참고하여 아래 자바스크립트로 할 수 있는 것들을 적어보도록 하겠습니다.

 

  • 웹사이트 개발
  • 웹서버 개발
  • 게임 개발
  • 모바일 앱 개발

자바스크립트는 독보적인 웹프로그래밍 언어로 웹페이지, 웹서버를 개발할 수 있습니다. 웹을 개발하고 싶으시다면 무조건 자바스크립트를 공부해야 합니다. 

뿐만 아니라 간단한 게임도 만들 수 있습니다. 그리고 요새 핫한 모바일 개발 또한 안드로이드 프로그래밍을 배우지 않고, 자바스크립트로 개발할 수 있습니다.

이밖에도 VR/AR이나 사물인터넷까지 충분히 다양한 분야에 자바스크립트를 활용할 수 있습니다. 


 

 

+ Recent posts