반응형

이전 포스팅에서 자비스 직원은 매장 내부에서 물/반찬 추가 요청 직접 수행, 식사 배달하는 역할을 하는 홀 서빙 담당이라고 설명했습니다. 홀에서 일하는 주방장이라고 할 수 있습니다. 커피, 팥빙수 등을 직접 만들어서 제공하기 때문입니다. 이 직원(JavaScript, 자바스크립트)에 대해서 알아보겠습니다. 자바 스크립트는 고수준 언어입니다. 이전 포스틩에서 설명드린 대로 고수준 언어는 저수준 언어보다 사람이 개발하기 쉽습니다. 이전에 보았던 HTML 이나 CSS는 마크업 언어로 어떤 동작이나 계산을 프로그래밍하기보다는 구성과 표현을 정의 할때 사용하는 언어였습니다. 그러나 자바스크립트는 계산과 처리를 중심으로 합니다. 자세히 살펴 보겠습니다.

JavaScript (자바 스크립트) : 홀 서빙 담당-홀 주방장

  • 정의
  • 기본 구조 및 문법
  • 샘플 코딩 해보기


정의

지난 포스팅의 식당 예시에서 자비스(JavaScript)를 정의한 내용은 아래와 같습니다.

  • 자비스 직원이 하는 일은 크게 2가지 입니다. 첫째는 홀에서 손님이 요청한 간단한 서비스를 제공하는 것입니다. 예를 들면 음료수라든가 물 부족한 반찬 등을 요청하면 자비스가 홀에 비치된 냉장고 같은 장치에서 꺼네서 제공합니다. 커피머신이나 빙수기 등 홀에 있는 장비를 이용하여 홀 안에서 고객응대를 잘 합니다. 복잡한 일도 잘 처리하고 미리 준비해 놓지 않아도 고객의 요청이 있으면 그때 그때 홀 장비를 이용해서 잘 처리 합니다.
  • 둘째는 주방에 (때로는 다른 가게에 가서까지) 손님이 원하는 요리를 요청하고 완성된 요리를 손님에게 전달 합니다. 가끔은 추신스 직원이 완성된 요리에 장식을 하기도 합니다.


이것을 웹 어플리케이션 관점에서 자바 스크립트를 다시 자세히 설명 드리겠습니다.

  • 자바 스크립트를 해석하고 실행하는 자바 스크립트 엔진이 모든 웹 브라우저에 있기 때문에 웹 어플리케이션에 가장 많이 사용되는 언어중 하나입니다.
  • 클라이언트에서의 웹페이지의 동작이나 외부 프로그램의 사용이 필요할 때 자바 스크립트를 사용합니다. HTML과 CSS는 정적인데 반하여 자바 스크립트를 이용하면 구성을 변경하거나 속성(위치, 크기, 색상 등)을 바꿀 수 있습니다. 이러한 기능을 이벤트와 연결하면 상황에 따라 바뀌는 홈페이지를 만들 수 있습니다. 예를 들면 마우스가 특정 지역에 들어가면 색상을 바꿀 수 있습니다. 이러한 계산을 위해 클라이언트의 자원(CPU)를 사용합니다. 산술 연산도 가능하고 외부 프로그램(라이브러리)을 이용해서 복잡하고 다양한 계산과 처리도 가능합니다. (이러한 능력 때문에 서버에서도 사용가능하지만 일단 클라이언트에서 사용한다고 생각하겠습니다.)
  • 이런 다양한 기능중 하나가 바로 외부, 특히 서버와의 통신 입니다. 마치 사용자가 주소창에 요청 내용을 입력한 것처럼 자바 스크립트는 서버에 요청을 보낼 수 있습니다. 그리고 응답을 받아서 가공을 할수 있고 이 결과를 가지고 HTML과 CSS 내용을 바꿀 수 있습니다. 그러면 사용자는 바뀌어진 내용을 웹 브라우저에서 볼 수 있게 됩니다.

특징

  • HTML, CSS와 함께 WWW의 핵심 기술중 하나입니다.
  • 세계에서 가장 인기 있는 프로그래밍 언어입니다.
  • 웹의 프로그래밍 언어입니다.
  • 배우기 쉬운 언어입니다.


기본 구조 및 문법

자, 이제 부터는 간단한 기본 구조와 문법에 대해서 알아보겠습니다. 우리의 목표는 JavaScript가 대략 어떤 것인지 이해하는 것이므로 아주 자세한 내용은 생략하겠습니다.

  • 위치와 구성 :
    • <head> 태그 또는 <body> 태그  내부에 위치 할 수 있습니다.
    • 내용은 <script>태그로 시작하고 </script> 로 닫습니다./끝납니다. 프로그램 내용을 이 사이에 정의합니다.
  • 공통 모든 문장의 끝은 ";"세미콜론 으로 끝납니다. 즉, 하나의 문장을 인식하는데 ";"을 이용합니다.
  • 입력/출력 방법 : html 요소, 팝업 메시지 창 등을 통해서 입출력 가능합니다. HTML 전체 내용을 document라는 객체를 통해 자바 스크립트에서 사용할 수 있습니다. 그래서 document를 통해 html 요소에 접근/설정 할 수 있습니다.
  • 변수의 사용이 가능합니다. abc = 1; 이란 명령어는 1을 abc 라는 변수에 할당하라는 명령입니다.
  • 처리 데이터 유형 : 자연수, 실수, 문자열, 리스트 등
  • 데이터 처리 / 연산자 : 사칙연산, 수학 함수, 할당문
  • 처리 흐름 제어문 : 조건문, 반복문, 제어문 등이 있습니다.
  • 함수 : 반복 사용되는 처리에 대한 정의 후 재사용
  • ………
  • HTML 요소와의 연계 : 자바 스크립트는 HTML 요소를 가져오고 변경해서 설정할 수 있습니다. 자바 스크립트 내에서 전체 HTML을 document 라는 친구가 가지고 있다고 생각하시면 됩니다. 그래서 이 친구에게 특정 요소를 가져달라고 하거나 설정해 달라고 할 수 있습니다.
  • 예시로 document에게 id가 id_number_1인 요소를 가져다 달라고 요청하고 결과를 id1 이라는 변수에 할당하려면 다음과이 할 수 있습니다. id1 = document.getElementById("id_number_1");  이렇게 하면 id_number_1 이라는 hrml 요소 전체가 id1에 저장된 것입니다. 그래서 id_number_1 요소의 속성 값들도 모두 id1에 저장되어있습니다. 이런 속성 값을 가져오기 위해 객체 뒤에 '.속성' 으로 값을 가져올 수 있습니다. 예를 들면 id1.value 라고 하면 입력박스(<input>) 요소의 text 값을 가져올 수 있습니다. document에 요청할때 처음부터 값을 요청할 수도 있습니다.( document.getElementById("id_number_1").value)
  • 이렇게 변수에 저장된 값은 이후 다른 계산이나 처리에 이용될 수 있으며 또 다른 요소에게 전달될 수 있습니다. 예를 들어 위에서 가져온 입력박스의 text 값을 해드라인의 text로 설정할 수 있습니다. 예를 들면 id가 out인 해드라인요소에 입력박스에서 가져온 id1.value를 할당 할 수 있습니다. document.getEnementById("out").innerHTML = id1.value;    

샘플 코딩 해보기 - 자바 스크립트 코딩

이제 어떻게 작성하는 지를 알았으니 아래와 같은 요건을 만족 시키는 자바 스크립트를 한번 만들어 보겠습니다. 자바 스크립트도 HTML과 같이 특별한 작성 프로그램이 필요하지 않습니다. 메모장 같은 모든 텍스트 작성 프로그램으로 작성이 가능합니다. 메모장을 열어서 위에서 배운 문법에 따라 자바 스크립트가 포함된 파일을 작성해 보시지요. 메모장이 없으시면 간단한 무료 텍스트 작성기를 다운 받아 사용할 수 있습니다. 여기 링크를 통해 운영체재에 맞는 sublime text라는 택스트 작성기를 다운 받아 사용하실 수 있습니다.

요건

다음의 요건 내용에 맞는 자바 스크립트 코딩을 해보겠습니다. 이전 CSS 때 만들었던 파일에 추가해 보세요. 파일이름을 03_javascript.html 이라고 바꾸어서 저장해주세요.

  • 입력박스 하나를 추가합니다. id를 nemo, value를 "취미코딩은 이렇게 하는 것 "으로 설정합니다.
  • id가 out_text인 해드라인(h2)를 추가합니다.
  • 위 입력박스의 내용에다가 " 입니다."라는 내용을 추가하여 해드라인에 표시합니다. 다시 자세히 말하면 id가 nemo 인 요소의 value를 가져와서 그 내용에 " 입니다."를 추가하여 id가 out_text인 요소의 value로 설정합니다.

취미 코딩 내용

한번 직접해 보셨나요?! 아래는 위의 요건을 이전에 만들었던 CSS 파일에 자바 스크립트 내용을 추가한 내용입니다.

<!DOCUMENT html>
<html>
<head>
<title>Welcome to HTML world!</title>
<style>
body {
background-color: yellow;
}

h1 {
color: blue;
text-align: center;
}
p {
color: orange;
}
</style>
</head>
<body>
<h1>Hello HTML!</h1>
<p>이것은 문단 입니다.</p>
<a href=”https://www.google.com”>Go To Google</a>

<input id="nemo" value='취미코딩은 이렇게 하는 것 '>
<h2 id="out_text"></h2>
<script>
var input_string = document.getElementById("nemo").value;
document.getElementById("out_text").innerHTML = input_string + " 입니다.";
</script>
</body>
</html>

작성 내용 확인

앞에서 작성한 내용을 03_javascript.html 파일로 저장하고 이 파일을 웹 브라우저에서 오픈하면 내용이 잘 작성되었는지 확인 할 수 있습니다.
아래 이미지는 위에서 작성한 코딩 파일을 크롬 브라우저에서 파일 열기를 통해 열었을 때 보여지는 내용입니다.

요약

이처럼 자바 스크립트를 이용하여 웹 브라우저에서 동작하는 많은 일들을 할 수 있습니다. 고수준의 프로그래밍 언어이기 때문에 쉽게 많은 일들을 할 수 있습니다. 위에서도 잠깐 말씀드렸지만 자바 스크립트를 가지고 서버 프로그래밍까지 가능합니다. 프론트엔드 개발에서 로직을 처리하는 부부분은 자바 스크립트가 담당한다고 생각하시면 되겠습니다.

이번 시간에는 JavaScript에 대해서 조금 더 구체적으로 알아 보았습니다. 기본 문법을 배웠고 간단한 요건을 충족시키는 JavaScript를 만들어 보았습니다.
다음 시간에는 서버 프로그램 개발에 사용되는 Python에 대해서 알아보도록 하겠습니다.

질문 댓글은 언제나 환영이며 구독, 좋아요를 눌러 주시면 다음 글을 더 편하게 보실 수 있습니다.

감사합니다.



반응형
반응형

이전 포스팅에서 추신스 직원은 하태민(HTML) 매니저를 돕기위해 매장 내 환경 셋팅을 전담한다고 설명했습니다. 이 직원(CSS)에 대해서 알아보겠습니다.

CSS : Cascading Style Sheets 홀 셋팅 담당

  • 정의
  • 기본 구조 및 문법
  • 샘플 코딩 해보기

 

정의

이전 포스팅의 식당 예시에서 추신스(CSS)을 정의한 내용은 아래와 같습니다.

  • 사실 추신스 직원은 하태민님의 소개로 식당에 취직하게 되었습니다.
  • 하태민님 혼자서 손님의 기호에 맞고 깔끔한 매장을 유지하기 위해 매장 내 테이블과 의자 등의 배치와 크기, 색상을 자주 바꾸는데 너무 힘 들었기 때문입니다. 그래서 추신스 직원은 이러한 배치, 크기, 색상 등 손님에게 보여지는 것 들을 전담으로 관리합니다.


이것을 웹 어플리케이션 관점에서 다시 자세히 설명 드리겠습니다.

  • CSS는 HTML과 같이 마크업 언어로 요소를 정의하기 위해 태그를 사용합니다.
  • CSS는 브라우저에서 보여지는 구성 요소들의 표현 속성을 설정하는 언어 입니다. 즉, 구성 요소의 위치, 크기, 색상 등을 정의 합니다.
  • HTML은 전체 구성을 CSS는 요소의 표현을 담당하게 되는 것 입니다. 이렇게 표현 속성만을 묶어서 CSS가 관리 함으로써 표현의 유연성이 높아지고 여러 다른 페이지(html)에서도 공통적으로 표현 속성을 사용할 수 있게 됩니다. 생각해 보세요! 50개의 웹 페이지가 있는데 모두 같은 배경색을 쓰다가 바뀌게 될 경우 프로그램의 50군대를 모두 바꾸어줘야 합니다. 그러나 CSS를 사용하여 별도 파일(.css)로 관리할 경우에는 이 파일에서만 수정해주면 한번에 모두 적용됩니다.

 

기본 구조 및 문법

자, 이제 부터는 간단한 기본 구조와 문법에 대해서 알아보겠습니다. 우리의 목표는 CSS가 대략 어떤 것인지 이해하는 것이므로 아주 자세한 내용은 생략하겠습니다.

  • CSS 정의 내용은 <html>태그와 <head> 태그 안쪽에 정의 됩니다. 또는 별도 파일로도 관리가 가능합니다.
  • <style> 태그로 시작합니다.
  • <style> 태그와 </style>태그 사이에 css 구성요소를 배치 합니다.
  • </style> 태그로 닫습니다./끝납니다.

CSS 구성요소

  • 요소는 "선택자 { 선언문 }" 으로 구성됩니다. 
  • 선택자는 html 태그 요소 또는 요소의 name/id 등으로 설정이 가능합니다. (예: h1, p, a)
  • 선언문은 “속성: 값” 으로 정의되고 하나의 선언문 끝은 ‘;’ 으로 구분됩니다. 
  • 주요 속성은 다음과 같습니다. color, text-align, background-color, background-image …
  • 요소의 예시는 아래와 같습니다. 
  • HTML 파일 내부에 CSS 내용을 추가했을 때의 예시 입니다.
<!DOCUMENT html>
<html>
<head>
<style>
h1 { color: blue };
</style>
</head>
<body>
<......>
</bod>
</html>

 

 

샘플 코딩 해보기 - css 코딩

이제 어떻게 작성하는 지를 알았으니 아래와 같은 요건을 만족 시키는 css 스크립트를 한번 만들어 보겠습니다. CSS는 HTML과 같이 작성에 특별한 프로그램이 필요하지 않습니다. 메모장 같은 모든 텍스트 작성 프로그램으로 작성이 가능합니다. 메모장을 열어서 위에서 배운 문법에 따라 css 파일을 작성해 보시지요. 메모장이 없으시면 간단한 무료 텍스트 작성기를 다운 받아 사용할 수 있습니다. 여기 링크를 통해 운영체재에 맞는 sublime text라는 택스트 작성기를 다운 받아 사용하실 수 있습니다.

요건

다음의 요건 내용에 맞는 CSS 코딩을 해보겠습니다. 이전 HTML 때 만들었던 파일에 추가해 보세요. 파일이름을 02_html_css.html 이라고 바꾸어서 저장해주세요.

  • 배경은 노란색
  • 글자 색은 파란색 그리고 중간에 배치
  • 헤드라인의 글자체는 verdana이고 크기는 20픽셀로 설정
  • 문단의 색은 오렌지 색으로 설정

 

샘플 코딩 내용

한번 직접해 보셨나요?! 아래는 위의 요건을 이전에 만들었던 HTML 파일에 CSS 내용을 추가한 내용입니다.

<!DOCUMENT html>
<html>
<head>
<title>Welcome to HTML world!</title>
<style>
body { background-color: yellow;}
h1 { color: blue; text-align: center;}
p { color: orange;}
</style>
</head>
<body>
<h1>Hello HTML!</h1>
<p>이것은 문단 입니다.</p>

</body>
</html>

 

작성 내용 확인

앞에서 작성한 내용을 .html로 끝나는 파일로 저장하고 이 파일을 웹 브라우저에서 오픈하면 내용이 잘 작성되었는지 확인 할 수 있습니다.
아래 이미지는 위에서 작성한 샘플 코딩 파일을 크롬 브라우저에서 파일 열기를 통해 열었을 때 보여지는 내용입니다.

 

 

요약

이처럼 CSS를 이용하여 웹 브라우저에서 보여지는 내용들을 설정 할 수 있습니다. 선택자의 경우 말씀 드린대로 html 속성으로 쓰이는 id나 name 등을 이용해서 한꺼번에/또는 특정해서 대상을 선택할 수 있습니다. 그리고 위치, 경계 마진 등 다양한 속성을 다룰 수 있습니다.

이번 시간에는 CSS에 대해서 조금 더 구체적으로 알아 보았습니다. 기본 문법을 배웠고 간단한 요건을 충족시키는 CSS를 만들어 보았습니다.
다음 시간에는 JavaScript에 대해서 알아보도록 하겠습니다.

질문 댓글은 언제나 환영이며 구독, 좋아요를 눌러 주시면 다음 글을 더 편하게 보실 수 있습니다.

감사합니다.




반응형
반응형

클라이언트(PC/노트북 내 브라우저)에서 주소창에 인터넷 주소를 입력하고 그내용을 서버에 요청하면 HTML 파일을 회신 받습니다. HTML파일은 회신 받는 내용의 전체 틀을 구성하기 때문에 받는 내용(파일) 중에서 가장 중요다고 할 수 있습니다. 이 HTML에 대해서 알아보겠습니다.

HTML : Hyper Text Markup Language 홀 담당 매니저

  • 정의
  • 기본 구조 및 문법
  • 샘플 코딩 해보기


정의

이전 포스팅의 식당 예시에서 하태민님(HTML)을 정의한 내용은 아래와 같습니다.

  • 식당 문을 열고 들어가면 식당 전체가 보이는 계산대에서 하태민님이 서 있습니다. 손님이 보는 관점에서 식당 전체를 관리하는 사람이 하태민님 입니다.
  • 하태민님은 홀이 손님에게 깔끔하고 잘 보여질 수 있게 하기위해 식당 협회에서 정한 기준을 잘 알고 이를 준수하는 직원으로 식당 매니저 5년차의 정규 직원입니다.
  • 매니저로서 손님에게 보여지는 식당 내 전체적인 구성과 배치, 설정을 관장 합니다.즉, 매장 내 테이블이나 의자, 메뉴판 등의 필요 여부를 정하고 위치와 크기, 모양, 색상 등을 정할 수 있습니다.
  • 제일 오래된 직원으로 추신스와 자비스를 품을 수 있는 오랜 베테랑 입니다.


이것을 웹 어플리케이션 관점에서 다시 설명 드리겠습니다.

  • HTML은 클라이언트 브라우저에서 보여지게되는 전체의 틀과 내용을 제공합니다. 즉, 브라우저에서 보여지는 모든 요소들의 구성과 속성을 정의하는 언어 입니다.
  • HTML은 브라우저에서 표시되는 것을 정하기 위해 사용되는 W3C 표준 마크업 언어입니다. 마크업 언어란 구성 요소를 정의하기 위해 태그를 사용하는 언어를 말합니다. HTML 5 버전이 사용중입니다.
  • HTML은 다양한 요소를 포함하여 구성할 수 있습니다. 요소에는 속성 값을 갖을 수 있으며 속성을 통해 통해 위치, 크기, 모양, 색상 등을 조정할 수 있습니다.
  • HTML 파일에 직접 CSS, JavaScript 내용을 포함 할 수도 있고 외부 링크로 표시하여 포함 할 수도 있습니다.
  • HTML은 특별한 작성 프로그램이 필요하지 않습니다. 일반 메모장이나 텍스트 작성기만 있으면 충분합니다. 저장시 확장자를 .html 또는 .htm 으로만 해주시면 됩니다. 그리고 저장된 파일을 웹 브라우저에서 열면 작성 내용을 볼 수 있습니다.

기본 구조 및 문법

자, 이제 부터는 간단한 기본 구조와 문법에 대해서 알아보겠습니다. 우리의 목표는 HTML이 대략 어떤 것인지 이해하는 것이므로 아주 자세한 내용은 생략하겠습니다.

  • 문서 내 모든 내용은 <요소명> 으로 시작하고 </요소명>으로 닫습니다.
  • 첫 줄은 <!DOCTYPE html> 입니다.
  • <html> 로 시작합니다.
  • <head> 와 </head>는 옵션입니다.
  • <body> 와 </body> 사이에 구성 요소를 위치 시킵니다.
  • 마지막은 </html>로 끝납니다.
  • 요소 안에는 또 다른 요소를 포함 할 수 있습니다. 단, 교차는 안됩니다.
  • 요소(Elements)의 예입니다. : <h1> : 해드라인, <p> : 문단, <a> : 링크, <img> : 이미지, <ul>, <ol>, <li> …..
  • 속성(Attributes) 의 예입니다. : <a> 태그의 href (하이퍼링크), <img> 태그의 src(소스위치), width, height,

샘플 코딩 해보기 - html 파일 만들기

이제 어떻게 작성하는 지를 알았으니 아래와 같은 요건을 만족 시키는 html을 한번 만들어 보겠습니다. HTML 작성에는 특별한 프로그램이 필요하지 않습니다. 메모장 같은 모든 텍스트 작성 프로그램으로 작성이 가능합니다. 메모장을 열어서 위에서 배운 문법에 따라 html 파일을 작성해 보시지요. 메모장이 없으시면 간단한 무료 텍스트 작성기를 다운 받아 사용할 수 있습니다. 여기 링크를 통해 운영체재에 맞는 sublime text라는 택스트 작성기를 다운 받아 사용하실 수 있습니다.

요건

  • 오른쪽 내용으로 타이들을 만드세요 (힌트<title> 사용): “Welcome to HTML world!”
  • 오른쪽 내용으로 해드라인을 만드세요 (힌트<h1>사용): “Hello HTML!”
  • 오른쪽 내용으로 문단을 작성하세요 (힌트<p>사용): “이것은 문단입니다.”
  • "Go To Google" 이라는 text 내용이 보이게 링크를 만드세요. 클릭하면 www.google.com 으로 연동되게 만드세요(힌트<a>사용)

샘플 코딩 내용

한번 직접해 보셨나요?! 아래는 위의 요건을 html 파일로 만들어본 내용입니다. 파일이름을 01_html.html 이라고 하겠습니다.(제일 뒤에 .html만 붙이면 앞은 어떤 이름이라도 상관 없습니다.)

<!DOCUMENT html>
<html>
<head>
<title>Welcome to HTML world!</title>
</head>
<body>
<h1>Hello HTML!</h1>
<p>이것은 문단 입니다.</p>
<a href="https://www.google.com”>Go To Google</a>
</body>
</html>

작성 내용 확인

앞에서 작성한 내용을 .html로 끝나는 파일로 저장하고 이 파일을 웹 브라우저에서 오픈하면 내용이 잘 작성되었는지 확인 할 수 있습니다.
아래 이미지는 위에서 작성한 샘플 코딩 파일을 크롬 브라우저에서 파일 열기를 통해 열었을 때 보여지는 내용입니다.


요약

이처럼 HTML 언어를 이용하여 웹 브라우저에서 보여지는 내용들을 구성하고 설정 할 수 있습니다. 더 많은 구성 요소(태그)를 학습하시면 박스라든가 표, 리스트 등 복잡하고 다양한 정보를 표시할 수 있습니다.

이번 시간에는 HTML에 대해서 조금 더 구체적으로 알아 보았습니다. 기본 문법과 구성요소(태그)를 가지고 간단한 HTML을 작성해 보았습니다.
다음 시간에는 CSS에 대해서 알아보도록 하겠습니다.

질문 댓글은 언제나 환영이며 구독, 좋아요를 눌러 주시면 다음 글을 더 편하게 보실 수 있습니다.

감사합니다.




반응형
반응형


지난 시간의 내용을 요약하면 웹 어플리케이션은 웹브라우저, 인터넷, 웹서버 등으로 구성되어 클라이언트(PC)에서 브라우저를 통해 사용할 수 있는 시스템을 웹 어플리케이션 시스템이라고 정의 했습니다. 클라이언트는 브라우저를 통해서 데이터의 전송과 수신을 담당하는데 이때 주소창에 입력하는 내용이 전송 내용이고 수신 내용으로는 HTML, CSS, JavaScript 등의 데이터가 수신된다고 하였습니다.
이처럼 HTML, CSS, JavaScript, 그리고 서버에서 동작하는 프로그램 언어인 자바(JAVA)나 파이썬(Python) 같은 언어들이 웹 어플리케이션(Web Application) 시스템에 사용되는 언어 입니다.
이번 시간에는 이러한 언어들에 대한 개요를 설명해 드리겠습니다.

자 시작해 보겠습니다.

목표 및 범위

  • 목표
  • Web Application 의 전반적인 구조를 이해하고,
  • 필요한 기술요소를 알 수 있으며,
  • 이에 필요한 언어들의 특징을 이해하고 설명할 수 있다. (이번 포스팅)
  • 범위
  • 전반적인 구조와 기술요소, 언어 특징에 대한 이해를 목표로하며,
  • 각 언어에 대한 실제적인 코딩 실력을 키우는 것은 이후 포스팅에서 진행합니다.



한식당 - 웹앱

여러분이 자주 가는 하나의 한식당 가게를 생각해 보시지요. 가게는 크게 홀과 주방으로 나누어 집니다. 직원은 4 명이 있고 각자 맏은 역할이 아래와 같다고 가정해 보겠습니다.

  • 하태민님 : 홀 담당 매니저 - 홀 전체의 구성을 관리하고 연계함
  • 추신스 : 홀 셋팅 직원 - 손님에 따라 다른 색, 크기, 모양의 테이블 등 환경 셋팅 담당
  • 자비스 : 홀 서빙 직원 - 물/반찬 추가 요청 직접 수행, 식사 배달
  • 파이썬 : 주방장 - 재료를 이용해서 주문받은 음식을 요리해서 전달

 

등장인물 직원 소개

하태민님

식당 문을 열고 들어가면 식당 전체가 보이는 계산대에서 하태민님이 서 있습니다. 손님이 보는 관점에서 식당 전체를 관리하는 사람이 하태민님 입니다.
하태민님은 홀이 손님에게 깔끔하고 잘 보여질 수 있게 하기위해 식당 협회에서 정한 기준을 잘 알고 이를 준수하는 직원으로 식당 매니저 5년차의 정규 직원입니다.
매니저로서 손님에게 보여지는 식당 내 전체적인 구성과 배치, 설정을 관장 합니다.즉, 매장 내 테이블이나 의자, 메뉴판 등의 필요 여부를 정하고 위치와 크기, 모양, 색상 등을 정할 수 있습니다.
제일 오래된 직원으로 추신스와 자비스를 품을 수 있는 오랜 베테랑 입니다.

추신스

사실 추신스 직원은 하태민님의 소개로 식당에 취직하게 되었습니다.
하태민님 혼자서 손님의 기호에 맞추어 깔끔한 매장을 유지하기 위해 매장 내 테이블과 의자 등의 배치와 크기, 색상을 자주 바꾸는데 너무 힘 들었기 때문입니다. 그래서 추신스 직원은 이러한 배치, 크기, 색상 등 손님에게 보여지는 것 들을 전담으로 관리합니다.

자비스

자비스 직원이 하는 일은 크게 2가지 입니다. 첫째는 홀에서 손님이 요청한 간단한 서비스를 제공하는 것입니다. 예를 들면 음료수라든가 물 부족한 반찬 등을 요청하면 자비스가 홀에 비치된 냉장고 같은 장치에서 꺼네서 제공합니다. 커피머신이나 빙수기 등 홀에 있는 장비를 이용하여 홀 안에서 고객응대를 잘 합니다. 복잡한 일도 잘 처리하고 미리 준비해 놓지 않아도 고객의 요청이 있으면 그때 그때 홀 장비를 이용해서 잘 처리 합니다.
둘째는 주방에 (때로는 다른 가게에 가서까지) 손님이 원하는 요리를 요청하고 완성된 요리를 손님에게 전달 합니다. 가끔은 추신스 직원이 완성된 요리에 장식을 하기도 합니다.

파이썬

파이썬은 주방장입니다. 파이썬은 네덜란드 출신입니다. 이 주방장은 항상 오픈된 주방에서만 일을 하기 때문에 주방장이 요리하는 순서나 내용을 다른 사람들이 쉽게 알 수 있습니다.
이 주방장은 어느 오픈 주방에서든지 요리를 잘합니다. 가끔 미리 준비된 재료(데이터)를 사용해서 주문이 들어오면 그때 그때 조리를 하기도 합니다.
또 급할때는 밀키트 처럼 미리 만들어 놓은 재료(오브젝트)를 기반으로 추가/변경하여 요리하기도 합니다.
이 주방장은 요리 중간에 들어간 재료를 확인하지 않아서 가끔 주요 재료가 빠진 식사가 잘 못나올 수 있기 때문에 조리 전에 주문에 맞게 재료가 맞게 들어가 있는지 확인해 줘야 합니다.

이상으로 등장인물의 소개를 마치겠습니다.


혹시 눈치 채셨나요?

네, 그렇습니다. 바로 웹 어플리케이션에서 쓰이는 언어의 구성을 식당으로 재구성한 내용입니다. 하태민님은 HTML, 추신스 직원은 CSS, 자비스 직원은 JavaScript, 파이썬 주방장은 Python 입니다. 홀은 클라이언트(PC/노트북)이고 주방은 웹/어플리케이션 서버를 말합니다.
이런 등장인물들이 서로 도와서 손님이 주문한 음식과 요리를 만들고 제공하며, 손님이 편하게 즐길 수 있도록 환경을 제공합니다. 웹 어플리케이션도 마찬가지로 서로 자기의 역할을 하면서 서비스를 제공합니다. 이처럼 모든 등장인물은 특성과 담당 특기가 있습니다. 여러분은 어떤 일이 마음에 드시는 지요? 여러분의 마음에 따라 사용하는 언어가 달라 질 수 있기 때문에 중요하다고 할 수 있겠습니다. 아직 개별 언에 대해 알아보진 않았지만 크게는 2가지로 나눌 수 있을 것 같습니다. 클라이언트에서 사용되는 언어와(HTML, CSS, JavaScript) 서버에서 사용되는 언어(Python 또는 JAVA)이 있습니다. 이 두 종류의 개발을 다른 말로 프론트엔드(Frontend) 개발과 백엔드(Backend) 개발이라고 나눕니다.

이번 시간에는 HTML, CSS, JavaScript, Python 언어의 역할에 대해서 알아 보았습니다.
다음 시간에는 각 언어별로 좀더 자세하게 알아보도록 하겠습니다.


질문 댓글은 언제나 환영이며 구독, 좋아요를 눌러 주시면 다음 글을 더 편하게 보실 수 있습니다.

감사합니다.


반응형

'취미코딩' 카테고리의 다른 글

취미코딩 - JavaScript란? 자바스크립트란?  (0) 2022.04.02
취미코딩 - CSS란?  (2) 2022.04.02
취미코딩 - HTML이란?  (0) 2022.04.02
취미코딩 - 웹 어플리케이션 이란?  (0) 2022.04.01
취미코딩- 1. 코딩이란?!  (0) 2022.03.29

+ Recent posts