Study/코드스테이츠 부트캠프

[코드스테이츠] 04_12_TIL : 프론트엔드 이해하기

Wise The 2023. 4. 12. 18:10
728x90
반응형

Today I Lean

프론트엔드 이해하기

 

아침에 일어나서 바로 공부를 시작하는게 습과이 안돼있어서 그런지 쉽지 않았다.

그래도 최대한 준비시간을 줄여보고자 커피도 미리 타놓고 긴장하고 잠들었던게 효과가 있었는지 제대로 일어나서 수업에 참여할 수 있어서 나름의 뿌듯함을 느낄수 있었다.

 

사실 HTML과 CSS는 공부했던 적이 있어서 아는 내용이긴 하지만 그래도 한 번 더 복습하는 느낌으로 정독하고 정리도 했다. 그 과정에서 배웠지만 잊고 있던 것들과 미처 알지 못했던 내용, 긴가민가 했던 부분까지 확실하게 알 수 있어서 좋은 배움의 시간이라고 느껴진다.

 

내일부터는 진짜 모르는 내용이 나와서 긴장되지만 그와 동시에 설레는 마음도 함께 있다.

HTML도 처음엔 어려웠는데 이제는 읽을 수 있는것처럼 JAVA도 계속 하다보면 언젠가는 잘 할 수 있을 테니 꾸준히 노력해 봐야겠다는 생각을 하며 오늘을 마친다. 

 

 

 

 

학습목표 및 개념정리

#  컴퓨터와 프로그래밍의 이해

- 컴퓨터의 구성 요소에 관해 설명할 수 있다.
- 프로그램을 실행하면 컴퓨터 내부에서 어떤 일이 일어나는지 이해할 수 있다.
- 프로그래밍과 관련된 개념들을 설명할 수 있다.
 (프로그램, 프로그래밍, 프로그래밍 언어, 컴파일, 빌드, 통합개발환경)

# 웹

- 웹 클라이언트와 웹 서버가 무엇인지 설명할 수 있다.
- 웹 프론트엔드에서 활용하는 핵심 기술인 HTML, CSS, JS가 무엇이고, 어떤 역할을 하는지 설명할 수 있다.

#  HTML

- HTML이 "구조를 표현하는 언어" 라는 것을 이해한다.

- HTML의 기본적인 구조를 이해한다.

- 자주 사용되는 HTML 요소(Element)를 설명할 수 있다.

 (<div>, <span>, <ul>, <ol>, <li>, <input> 등)


#  CSS

- CSS의 사용 목적을 이해하고, 기본적인 문법과 구조를 설명할 수 있다.

- HTML 에 CSS를 적용하는 방법에 대해 이해할 수 있다.

- HTML 파일 내에 CSS를 정의하는 것을 권장하지 않는 이유를 설명할 수 있다.

- CSS를 이용해 텍스트를 꾸밀 수 있다.

- 기본적인 CSS 박스 모델을 이해하고 설명할 수 있다.

 

#  Chat GPT를 활용한 학습 방법

 

 

 

 

배운 것

# 컴퓨터와 프로그래밍의 이해

1. 컴퓨터란?

- 입력받은 데이터를  → 하드웨어
 : 데이터를 입력장치로 입력받는다.(키보드, 마우스, 마이크 등)

정해진 규칙대로 → "소프트웨어"
 : 시스템 소프트웨어 (응용소프트웨어의 실행환경, 장치관리 드라이버)
 : 응용 소프트웨어 (프로그램 / 애플리케이션)

처리해서 → 하드웨어
 : 중앙처리장치를 통해 연산을 수행한다.(CPU>Center Processing Unit)

- 처리 결과를 저장하고 → 하드웨어
 : 기억장치에 저장한다.(하드디스크 드라이브)
 : 용량이 작을 수록 속도와가격은 높고, 용량이 클수록 속도와 가격은 낮아짐

출력하는 전자 장치 이다 → 하드웨어
 : 출력장치로 출력한다.(모니터, 스피커, 프린터 등)

- 그 외로 기기들을 연결하는 전선이 있다.  → 하드웨어
 : 시스템 버스라고 하는데, 각 하드웨어를 물리적으로 연결한 전선을 의미


2. 프로그래밍

- 프로그래밍 언어
 : 컴퓨터와 사람의 언어를 매개해 주는 것

- 컴파일
 : 프로그래밍 언어로 작성된 코드를 컴퓨터 언어로 변환하는 과정

- 빌드
 : 실행할 수 있는 확장자를 가진 파일로 만들어 주는 과정
 : 컴파일 과정이 빌드 안에 속한다.


3. 통합개발환경 (Integrated Development Environment, IDE)

 : 코드를 작성할 대 사용하는 프로그램 (디버깅, 빌드 등의 작업도 가능)
 : VScode, IntelliJ, Eclipse



# 웹

1. 웹 클라이언트와 웹 서버

- 2티어 아키텍처 / 클라이언트-서버
 : 리소스를 사용하는 곳 : 앱(클라이언트)
 : 리소스를 제공(serve) 하는 곳 : 서버

- 3티어 아키텍처 / 클라이언트-서버-데이터베이스
 : 리소스를 사용하는 곳 : 앱(클라이언트)
 : 리소스를 전달 하는 곳 : 서버
 : 리소스를 저장하는 곳 : 데이터베이스(서버에 속함)

* 리소스란?
사용될 수 있는 어떤 항목
프린터, 디스크 드라이브와 같은 장치 or 메모리
마이크로소프트 윈도우나 매킨토시와 같은 많은 운영체계에서, 리소스라는 용어는 프로그램들이 활용할 수 있는 데이터나 루틴들을 말한다.

- 종류
 : 클라이언트 (웹, 앱)
 : 서버 (성격에 따라 달라짐)

 

 

2. 클라이언트와 웹 서버

- HTML
 : 화면의 기본적인 구조를 짜고 스케치를 그려준다. 
 : 원하는 항목들을 쭉 나열하는 식

- CSS
 : HTML로 만든 스케치 위에 채색을 하고 그리드를 정렬 하는 등 더 다양한 화면을 그릴 수 있다.
 : CSS에서 움직임이 없는 정적인 화면을 만들 수 있다.

- JAVA SCRIPT
 : 화면에 생동감을 주며 움직임을 줄 수 있다.
 : 같은 화면에서 탭을 누를 때 여러번 로드 하지 않도록 해준다.


 

 

# HTML

1. 기본 구조와 문법

- HTML은 tag의 집합이다.
 : tag <>로 묶인 HTML의 기본요소

 

 

2. 자주 사용하는 HTML 요소

- <div>
 : div는 한 줄을 차지

 → 따로 정렬이나 사이즈 조절을 하지 않는이상 같은 줄에 다른 요소가 들어갈 수 없다.

 

- <span>
 : 컨텐츠의 크기만큼 공간을 차지

 

- <img>
 : <img src = "링크">

 → 닫는 태그 없음

 

- <a>

 : <a href = "링크" target = "_blank"></a>

 → a태그는 문서 전체에 스타일을 줬을 때 적용되지 않기 때문에  따로 줘야 함

 → 하이퍼링크

 

- <ul> - <li> / <ol> - <li>
 : 리스트를 만드는 태그

 → ul (점으로 표시)

 → ol (숫자로 표시)

 

- <input>, <textarea>

 → 입력폼

 : <input type = "text" placeholder = "type here">

 →

 : <textarea></textarea>

 →

 : <input type = "checkbox">

 →

 : <input type = "radio">

 →

 : <input type = "radio" name = "choice" value = "a">a

   <input type = "radio" name = "choice" value = "b">b

 → ab

 : <button>닫기</button>

 →

 

 

 

# CSS

1. CSS 와 UI / UX

- UI (User Interface)
 : 사용자 인터페이스 / 서비스와 사용자를 연결해주는 매개

 

- UX (User eXperience)
 : 사용자 경험 / 사용자가 편리하도록 깔끔하고 직관적인 페이지 구성

 

 

2. CSS 따라하기

- 시멘틱 태그 (semanric tag)
 : div를 대신하여 사용할 수 있는 태그

 → 기능은 같지만 사용자 편의를 위해 조금더 직관적인 이름이 달린 태그

 

- CSS 파일 추가
 : <link rel = "stylesheet" href = "../index.css" type = "text/css">

 → HTML과 CSS파일 연결

 

- CSS 파일 추가
 : <link rel = "stylesheet" href = "../index.css" type = "text/css">

 → HTML과 CSS파일 연결

 

- id / class
 : id

 → #

 → 한 문서내의 유일한 속성값

 → 특정 요소에 특별한 이름을 붙이는 데에 사용

 

 : class

 → .

 → 한 문서 내에 여러개 중복이 가능한 속성값

 → 스타일의 분류에 사용

 

 

3. BOX

- 박스 모델

 : 웹 페이지의 콘텐츠가 가지고 있는 영역

 : 줄바꿈(block) / 옆(inline, inline-block)

 

- 박스의 구성요소

* { 

     box-sizing : border-box;

}

 → 여백과 테두리를 포함한 크기로 박스 사이즈가 계산된다.

 → 전체 설정 * 에 지정

 

 

#프레임워크와 IDE의 차이

1. 프레임워크

 : 대표적인 프레임워크로는 웹개발에서 사용되는 Spring, Django, Ruby on Ralls 등이 있다.

- 표준화된 구조와 규칙 제공

- 재사용 가능한 코드 제공

- 개발의 생산성을 높이고, 유지보수를 용이하게 함

- 보안과 성능 최적화를 위한 기능제공

- 커뮤니티 지원과 다양한 플러그인, 라이브러리를 제공

 

2. IDE

 : 대표적인 IDE로는 Eclipse, IntelliJ IDEA, NetBeans 등이 있다.

- 통합 개발 환경 (Integrated Development Enviromment)

- 소프트웨어 개발을 위한 툴 들을 모아놓은 프로그램

- 코드 작성, 디버깅, 빌드, 배포 등을 지원하여 개발 생산성을 높임

 

Q&A

Q. 두개가 같은 건가?

 A. 프레임워크는 소프트웨어 개발을 위한 구조와 규칙을 제공하고 개발자는 이를 활용해 소프트웨어를 구현한다. IDE는 개발의 생산성을 높이는 통합개발환경 으로 상호작용을 하며 함께 사용할 수는 있지만, 이 둘은 같은 것은 아니다.

 

Q. 둘다 개발할 때 사용하는거 아닌가?

 A. 맞다. 둘다 소프트웨어 개발에 필요한 도구 이지만, 다른 목적과 기능을 가지고 있다.

 

Q. 그럼 프레임워크는 유지보수용이고, IDE는 개발용?

 A. 프레임워크는 유지보수에도 큰 도움을 주지만, 개발초기 단계에서도 사용되기 때문에 기능을 정확하게 나눌 수 없다. 결론적으로 프레임워크와 IDE는 모두 소프트웨어를 개발할 때 사용하지만, 어디에 더 중점을 두었느냐의 차이라고 할 수 있다.

프레임워크는 일관성과 유지보수성을 높이는 것에 중점을 두기 때문에 기능의 구조와 규칙을 제공한다.

IDE는 개발의 생산성을 높이는데 중점을 두기 때문에 코드작성, 디버깅, 빌드, 테스트, 배포 등의 기능을 제공한다.

그렇기 때문에 개발할 때 어떤 도구를 사용할 것인지는 프로젝트의 목적과 개발자의 선호도에 따라 달라진다.

 

Q. 크게 봤을때 IDE에 프레임워크가 포함되는건가?

 A. 그건 아니다.

 

 

 

 

Tomorrow Chapter

# 실습 툴 설치 및 실행

# CLI 기본 명령어

# 패키지와 패키지 매니저

# 사용권한

# 환경변수

 

 

 


 

 

↓ 이전 글 ↓

 

[코드스테이츠] 04_11_TIL : 코딩을 시작하기에 앞서...

Today I Lean 코딩을 시작하기에 앞서... 오랜만에 오랜시간 앉아있으려 하니 쉽지 않다고 생각이 들었다. 오늘은 그래도 첫날이라 어려운 부분이 없고 부트캠프과정에 대한 자세한 설명이 많았는

theflower01.tistory.com

 

 

↓ 코트스테이츠 부트캠프 관련 글 한번에 보기 ↓

 

'IT/코드스테이츠 부트캠프' 카테고리의 글 목록

Flower, Plant, Study

theflower01.tistory.com

 

728x90
반응형