🚴‍♂️
TIL
  • MAIN
  • : TIL?
  • : WIL
  • : Plan
  • : Retrospective
    • 21Y
      • Wait a moment!
      • 9M 2W
      • 9M1W
      • 8M4W
      • 8M3W
      • 8M2W
      • 8M1W
      • 7M4W
      • 7M3W
      • 7M2W
      • 7M1W
      • 6M5W
      • 1H
    • 새사람 되기 프로젝트
      • 2회차
      • 1회차
  • TIL : ML
    • Paper Analysis
      • BERT
      • Transformer
    • Boostcamp 2st
      • [S]Data Viz
        • (4-3) Seaborn 심화
        • (4-2) Seaborn 기초
        • (4-1) Seaborn 소개
        • (3-4) More Tips
        • (3-3) Facet 사용하기
        • (3-2) Color 사용하기
        • (3-1) Text 사용하기
        • (2-3) Scatter Plot 사용하기
        • (2-2) Line Plot 사용하기
        • (2-1) Bar Plot 사용하기
        • (1-3) Python과 Matplotlib
        • (1-2) 시각화의 요소
        • (1-1) Welcome to Visualization (OT)
      • [P]MRC
        • (2강) Extraction-based MRC
        • (1강) MRC Intro & Python Basics
      • [P]KLUE
        • (5강) BERT 기반 단일 문장 분류 모델 학습
        • (4강) 한국어 BERT 언어 모델 학습
        • [NLP] 문장 내 개체간 관계 추출
        • (3강) BERT 언어모델 소개
        • (2강) 자연어의 전처리
        • (1강) 인공지능과 자연어 처리
      • [U]Stage-CV
      • [U]Stage-NLP
        • 7W Retrospective
        • (10강) Advanced Self-supervised Pre-training Models
        • (09강) Self-supervised Pre-training Models
        • (08강) Transformer (2)
        • (07강) Transformer (1)
        • 6W Retrospective
        • (06강) Beam Search and BLEU score
        • (05강) Sequence to Sequence with Attention
        • (04강) LSTM and GRU
        • (03강) Recurrent Neural Network and Language Modeling
        • (02강) Word Embedding
        • (01강) Intro to NLP, Bag-of-Words
        • [필수 과제 4] Preprocessing for NMT Model
        • [필수 과제 3] Subword-level Language Model
        • [필수 과제2] RNN-based Language Model
        • [선택 과제] BERT Fine-tuning with transformers
        • [필수 과제] Data Preprocessing
      • Mask Wear Image Classification
        • 5W Retrospective
        • Report_Level1_6
        • Performance | Review
        • DAY 11 : HardVoting | MultiLabelClassification
        • DAY 10 : Cutmix
        • DAY 9 : Loss Function
        • DAY 8 : Baseline
        • DAY 7 : Class Imbalance | Stratification
        • DAY 6 : Error Fix
        • DAY 5 : Facenet | Save
        • DAY 4 : VIT | F1_Loss | LrScheduler
        • DAY 3 : DataSet/Lodaer | EfficientNet
        • DAY 2 : Labeling
        • DAY 1 : EDA
        • 2_EDA Analysis
      • [P]Stage-1
        • 4W Retrospective
        • (10강) Experiment Toolkits & Tips
        • (9강) Ensemble
        • (8강) Training & Inference 2
        • (7강) Training & Inference 1
        • (6강) Model 2
        • (5강) Model 1
        • (4강) Data Generation
        • (3강) Dataset
        • (2강) Image Classification & EDA
        • (1강) Competition with AI Stages!
      • [U]Stage-3
        • 3W Retrospective
        • PyTorch
          • (10강) PyTorch Troubleshooting
          • (09강) Hyperparameter Tuning
          • (08강) Multi-GPU 학습
          • (07강) Monitoring tools for PyTorch
          • (06강) 모델 불러오기
          • (05강) Dataset & Dataloader
          • (04강) AutoGrad & Optimizer
          • (03강) PyTorch 프로젝트 구조 이해하기
          • (02강) PyTorch Basics
          • (01강) Introduction to PyTorch
      • [U]Stage-2
        • 2W Retrospective
        • DL Basic
          • (10강) Generative Models 2
          • (09강) Generative Models 1
          • (08강) Sequential Models - Transformer
          • (07강) Sequential Models - RNN
          • (06강) Computer Vision Applications
          • (05강) Modern CNN - 1x1 convolution의 중요성
          • (04강) Convolution은 무엇인가?
          • (03강) Optimization
          • (02강) 뉴럴 네트워크 - MLP (Multi-Layer Perceptron)
          • (01강) 딥러닝 기본 용어 설명 - Historical Review
        • Assignment
          • [필수 과제] Multi-headed Attention Assignment
          • [필수 과제] LSTM Assignment
          • [필수 과제] CNN Assignment
          • [필수 과제] Optimization Assignment
          • [필수 과제] MLP Assignment
      • [U]Stage-1
        • 1W Retrospective
        • AI Math
          • (AI Math 10강) RNN 첫걸음
          • (AI Math 9강) CNN 첫걸음
          • (AI Math 8강) 베이즈 통계학 맛보기
          • (AI Math 7강) 통계학 맛보기
          • (AI Math 6강) 확률론 맛보기
          • (AI Math 5강) 딥러닝 학습방법 이해하기
          • (AI Math 4강) 경사하강법 - 매운맛
          • (AI Math 3강) 경사하강법 - 순한맛
          • (AI Math 2강) 행렬이 뭐예요?
          • (AI Math 1강) 벡터가 뭐예요?
        • Python
          • (Python 7-2강) pandas II
          • (Python 7-1강) pandas I
          • (Python 6강) numpy
          • (Python 5-2강) Python data handling
          • (Python 5-1강) File / Exception / Log Handling
          • (Python 4-2강) Module and Project
          • (Python 4-1강) Python Object Oriented Programming
          • (Python 3-2강) Pythonic code
          • (Python 3-1강) Python Data Structure
          • (Python 2-4강) String and advanced function concept
          • (Python 2-3강) Conditionals and Loops
          • (Python 2-2강) Function and Console I/O
          • (Python 2-1강) Variables
          • (Python 1-3강) 파이썬 코딩 환경
          • (Python 1-2강) 파이썬 개요
          • (Python 1-1강) Basic computer class for newbies
        • Assignment
          • [선택 과제 3] Maximum Likelihood Estimate
          • [선택 과제 2] Backpropagation
          • [선택 과제 1] Gradient Descent
          • [필수 과제 5] Morsecode
          • [필수 과제 4] Baseball
          • [필수 과제 3] Text Processing 2
          • [필수 과제 2] Text Processing 1
          • [필수 과제 1] Basic Math
    • 딥러닝 CNN 완벽 가이드 - Fundamental 편
      • 종합 실습 2 - 캐글 Plant Pathology(나무잎 병 진단) 경연 대회
      • 종합 실습 1 - 120종의 Dog Breed Identification 모델 최적화
      • 사전 훈련 모델의 미세 조정 학습과 다양한 Learning Rate Scheduler의 적용
      • Advanced CNN 모델 파헤치기 - ResNet 상세와 EfficientNet 개요
      • Advanced CNN 모델 파헤치기 - AlexNet, VGGNet, GoogLeNet
      • Albumentation을 이용한 Augmentation기법과 Keras Sequence 활용하기
      • 사전 훈련 CNN 모델의 활용과 Keras Generator 메커니즘 이해
      • 데이터 증강의 이해 - Keras ImageDataGenerator 활용
      • CNN 모델 구현 및 성능 향상 기본 기법 적용하기
    • AI School 1st
    • 현업 실무자에게 배우는 Kaggle 머신러닝 입문
    • 파이썬 딥러닝 파이토치
  • TIL : Python & Math
    • Do It! 장고+부트스트랩: 파이썬 웹개발의 정석
      • Relations - 다대다 관계
      • Relations - 다대일 관계
      • 템플릿 파일 모듈화 하기
      • TDD (Test Driven Development)
      • template tags & 조건문
      • 정적 파일(static files) & 미디어 파일(media files)
      • FBV (Function Based View)와 CBV (Class Based View)
      • Django 입문하기
      • 부트스트랩
      • 프론트엔드 기초다지기 (HTML, CSS, JS)
      • 들어가기 + 환경설정
    • Algorithm
      • Programmers
        • Level1
          • 소수 만들기
          • 숫자 문자열과 영단어
          • 자연수 뒤집어 배열로 만들기
          • 정수 내림차순으로 배치하기
          • 정수 제곱근 판별
          • 제일 작은 수 제거하기
          • 직사각형 별찍기
          • 짝수와 홀수
          • 체육복
          • 최대공약수와 최소공배수
          • 콜라츠 추측
          • 크레인 인형뽑기 게임
          • 키패드 누르기
          • 평균 구하기
          • 폰켓몬
          • 하샤드 수
          • 핸드폰 번호 가리기
          • 행렬의 덧셈
        • Level2
          • 숫자의 표현
          • 순위 검색
          • 수식 최대화
          • 소수 찾기
          • 소수 만들기
          • 삼각 달팽이
          • 문자열 압축
          • 메뉴 리뉴얼
          • 더 맵게
          • 땅따먹기
          • 멀쩡한 사각형
          • 괄호 회전하기
          • 괄호 변환
          • 구명보트
          • 기능 개발
          • 뉴스 클러스터링
          • 다리를 지나는 트럭
          • 다음 큰 숫자
          • 게임 맵 최단거리
          • 거리두기 확인하기
          • 가장 큰 정사각형 찾기
          • H-Index
          • JadenCase 문자열 만들기
          • N개의 최소공배수
          • N진수 게임
          • 가장 큰 수
          • 124 나라의 숫자
          • 2개 이하로 다른 비트
          • [3차] 파일명 정렬
          • [3차] 압축
          • 줄 서는 방법
          • [3차] 방금 그곡
          • 거리두기 확인하기
        • Level3
          • 매칭 점수
          • 외벽 점검
          • 기지국 설치
          • 숫자 게임
          • 110 옮기기
          • 광고 제거
          • 길 찾기 게임
          • 셔틀버스
          • 단속카메라
          • 표 편집
          • N-Queen
          • 징검다리 건너기
          • 최고의 집합
          • 합승 택시 요금
          • 거스름돈
          • 하노이의 탑
          • 멀리 뛰기
          • 모두 0으로 만들기
        • Level4
    • Head First Python
    • 데이터 분석을 위한 SQL
    • 단 두 장의 문서로 데이터 분석과 시각화 뽀개기
    • Linear Algebra(Khan Academy)
    • 인공지능을 위한 선형대수
    • Statistics110
  • TIL : etc
    • [따배런] Kubernetes
    • [따배런] Docker
      • 2. 도커 설치 실습 1 - 학습편(준비물/실습 유형 소개)
      • 1. 컨테이너와 도커의 이해 - 컨테이너를 쓰는이유 / 일반프로그램과 컨테이너프로그램의 차이점
      • 0. 드디어 찾아온 Docker 강의! 왕초보에서 도커 마스터로 - OT
    • CoinTrading
      • [가상 화폐 자동 매매 프로그램] 백테스팅 : 간단한 테스팅
    • Gatsby
      • 01 깃북 포기 선언
  • TIL : Project
    • Mask Wear Image Classification
    • Project. GARIGO
  • 2021 TIL
    • CHANGED
    • JUN
      • 30 Wed
      • 29 Tue
      • 28 Mon
      • 27 Sun
      • 26 Sat
      • 25 Fri
      • 24 Thu
      • 23 Wed
      • 22 Tue
      • 21 Mon
      • 20 Sun
      • 19 Sat
      • 18 Fri
      • 17 Thu
      • 16 Wed
      • 15 Tue
      • 14 Mon
      • 13 Sun
      • 12 Sat
      • 11 Fri
      • 10 Thu
      • 9 Wed
      • 8 Tue
      • 7 Mon
      • 6 Sun
      • 5 Sat
      • 4 Fri
      • 3 Thu
      • 2 Wed
      • 1 Tue
    • MAY
      • 31 Mon
      • 30 Sun
      • 29 Sat
      • 28 Fri
      • 27 Thu
      • 26 Wed
      • 25 Tue
      • 24 Mon
      • 23 Sun
      • 22 Sat
      • 21 Fri
      • 20 Thu
      • 19 Wed
      • 18 Tue
      • 17 Mon
      • 16 Sun
      • 15 Sat
      • 14 Fri
      • 13 Thu
      • 12 Wed
      • 11 Tue
      • 10 Mon
      • 9 Sun
      • 8 Sat
      • 7 Fri
      • 6 Thu
      • 5 Wed
      • 4 Tue
      • 3 Mon
      • 2 Sun
      • 1 Sat
    • APR
      • 30 Fri
      • 29 Thu
      • 28 Wed
      • 27 Tue
      • 26 Mon
      • 25 Sun
      • 24 Sat
      • 23 Fri
      • 22 Thu
      • 21 Wed
      • 20 Tue
      • 19 Mon
      • 18 Sun
      • 17 Sat
      • 16 Fri
      • 15 Thu
      • 14 Wed
      • 13 Tue
      • 12 Mon
      • 11 Sun
      • 10 Sat
      • 9 Fri
      • 8 Thu
      • 7 Wed
      • 6 Tue
      • 5 Mon
      • 4 Sun
      • 3 Sat
      • 2 Fri
      • 1 Thu
    • MAR
      • 31 Wed
      • 30 Tue
      • 29 Mon
      • 28 Sun
      • 27 Sat
      • 26 Fri
      • 25 Thu
      • 24 Wed
      • 23 Tue
      • 22 Mon
      • 21 Sun
      • 20 Sat
      • 19 Fri
      • 18 Thu
      • 17 Wed
      • 16 Tue
      • 15 Mon
      • 14 Sun
      • 13 Sat
      • 12 Fri
      • 11 Thu
      • 10 Wed
      • 9 Tue
      • 8 Mon
      • 7 Sun
      • 6 Sat
      • 5 Fri
      • 4 Thu
      • 3 Wed
      • 2 Tue
      • 1 Mon
    • FEB
      • 28 Sun
      • 27 Sat
      • 26 Fri
      • 25 Thu
      • 24 Wed
      • 23 Tue
      • 22 Mon
      • 21 Sun
      • 20 Sat
      • 19 Fri
      • 18 Thu
      • 17 Wed
      • 16 Tue
      • 15 Mon
      • 14 Sun
      • 13 Sat
      • 12 Fri
      • 11 Thu
      • 10 Wed
      • 9 Tue
      • 8 Mon
      • 7 Sun
      • 6 Sat
      • 5 Fri
      • 4 Thu
      • 3 Wed
      • 2 Tue
      • 1 Mon
    • JAN
      • 31 Sun
      • 30 Sat
      • 29 Fri
      • 28 Thu
      • 27 Wed
      • 26 Tue
      • 25 Mon
      • 24 Sun
      • 23 Sat
      • 22 Fri
      • 21 Thu
      • 20 Wed
      • 19 Tue
      • 18 Mon
      • 17 Sun
      • 16 Sat
      • 15 Fri
      • 14 Thu
      • 13 Wed
      • 12 Tue
      • 11 Mon
      • 10 Sun
      • 9 Sat
      • 8 Fri
      • 7 Thu
      • 6 Wed
      • 5 Tue
      • 4 Mon
      • 3 Sun
      • 2 Sat
      • 1 Fri
  • 2020 TIL
    • DEC
      • 31 Thu
      • 30 Wed
      • 29 Tue
      • 28 Mon
      • 27 Sun
      • 26 Sat
      • 25 Fri
      • 24 Thu
      • 23 Wed
      • 22 Tue
      • 21 Mon
      • 20 Sun
      • 19 Sat
      • 18 Fri
      • 17 Thu
      • 16 Wed
      • 15 Tue
      • 14 Mon
      • 13 Sun
      • 12 Sat
      • 11 Fri
      • 10 Thu
      • 9 Wed
      • 8 Tue
      • 7 Mon
      • 6 Sun
      • 5 Sat
      • 4 Fri
      • 3 Tue
      • 2 Wed
      • 1 Tue
    • NOV
      • 30 Mon
Powered by GitBook
On this page
  • HTML 기초
  • HTML 스타일 입히기
  • CSS
  • JS 기초
  • JS 파일로 관리하기

Was this helpful?

  1. TIL : Python & Math
  2. Do It! 장고+부트스트랩: 파이썬 웹개발의 정석

프론트엔드 기초다지기 (HTML, CSS, JS)

210706

Previous부트스트랩Next들어가기 + 환경설정

Last updated 3 years ago

Was this helpful?

HTML 기초

Front End

  • 사용자 눈에 보이고 만져서 조작하는 부분

  • 자동차의 핸들, 브레이크, 좌석 등

Back End

  • 사용자 눈에 보이지 않지만 실제 동작을 위한 부분

  • 핸들을 돌리면 바퀴가 돌아가는 기능.

실습을 위해 깃허브를 생성한다.

저장소를 다운 할 위치를 설정한다. 본문에서는 github 로 폴더를 생성. 나는 django 로 생성하겠다. 생성하는 방법은 mkdir foldername

  • mkdir foldername : 입력한 이름을 가진 폴더를 생성한다.

  • cd foldername : 입력한 이름을 가진 폴더로 현재 디렉토리를 변경한다.

이후, CMDer로 github 페이지를 clone 한다.

git clone : github repository를 로컬 저장소로 다운한다.

  • github : repository가 저장되어 있는 원격 공간.

  • repository : 저장소를 의미하며, 자신이 작업하고자 하는 작업 공간으로 생각해도 된다.

여기서, 나는 HTTP방식이 아닌, SSH 방식으로 clone을 진행할 것이다. HTTP는 git push 를 할 때 마다 아이디와 비밀번호를 요구하기 때문. (전자로 해도 무방하다)

1. 기존에 SSH Key가 존재하는지 확인

아무것도 뜨지 않으면 존재하지 않음!

2. SSH Key 생성

ssh-keygen -t ed25519 -C "email@example.com"

자신의 이메일로 다음 명령어를 통해 SSH Key를 생성할 수 있다. ed25519 방식으로 동작하지 않는 경우에는 아래와 같이 RSA로 옵션을 변경해 SSH 키를 생성한다.

 ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

3. 저장 위치 및 비밀번호 지정

명령어를 입력하면 다음과 같이 저장할 위치와 비밀번호를 물어본다.

그냥 엔터를 누르면 기본 위치에 저장되며 비밀번호 역시 엔터를 누르면서 설정하지 않을 수 있다.

  • 깃허브에서는 비밀번호를 설정할 것을 권고한다.

입력하고 나면 다음과 같이 개인키와 공개키가 만들어졌다고 출력된다.

4. 개인키와 공개키 확인

개인키 확인은 다음 명령어를 통해 개인키를 확인할 수 있다. 이는 절대 공개하면 안되는 정보.

$ cat id_ed25519

$ cat C:\Users\32154049/.ssh/id_ed25519
# 내 개인키 실제 위치

공개키 확인도 마찬가지로 확인할 수있다.

$ cat id_ed25519.pub

$ cat C:\Users\32154049/.ssh/id_ed25519.pub
# 내 공개키 실제 위치

5. 공개키를 Github 계정에 등록

실행한 내용을 직접 복사하기 보다는 명령어로 복사하는 것이 좋다.

# macOS
$ pbcopy < ~/.ssh/id_ed25519.pub

# Windows
$ clip < ~/.ssh/id_ed25519.pub

이후, 복사한 공개키를 깃허브에 등록한다.

정상적으로 키가 생성된 모습. 이 키는 공개키이다.

이제 SSH 방식으로 git clone 을 해보겠다.

처음과 달리 경고창이 없어진 모습.

성공적으로 Clone 되었다.

VSCode에서 본격적으로 html 페이지를 만들어보자.

index.html

<!DOCTYPE html>
<html>
    <head>
        <title>상만두의 웹사이트</title>
    </head>
    <body>
        <nav>
            <a href="./index.html">Home</a>
            <a href="./blog_list.html">Blog</a>
            <a href="./about_me.html">About me</a>
        </nav>

        <h1>첫번째 크기 헤드라인</h1>
        <h2>두번째 크기 헤드라인</h2>
        <h3>세번째 크기 헤드라인</h3>
        <h4>첫번째 크기 헤드라인</h4>
        <h5>두번째 크기 헤드라인</h5>
        <h6>세번째 크기 헤드라인</h6>

        <p>동해물과 백두산이 마르고 닳도록</p>
        <a href="https://google.com">Go to google</a>
        
        <hr/>

        <img src="images/photo1.jpg" width="600px">
    </body>
</html>

<!DOCTYPE html>

  • html언어라는 것을 나타내는 약속. 문서 첫 줄에 위치한다.

  • <! 만 입력해도 자동완성이 된다.

<html>

  • 문서를 이루는 가장 큰 태그

<head>

  • 타이틀을 작성할 수 있다

<body>

  • 페이지의 내용을 작성할 수 있다

<nav>

  • 네비게이션 바를 만들 수 있다.

<h>

  • 헤더 태그

  • <h1> 부터 <h6> 까지 있으며, 숫자가 작을 수록 글씨가 커진다.

<p>

  • 일반 텍스트 태그

<a>

  • 링크 등을 삽입할 때 사용한다.

<hr/>

  • 수평선을 그을 때 사용한다.

  • 닫아주는 태그가 없이 혼자서 사용한다.

<img>

  • 이미지를 삽입할 때 사용한다.

  • src = "경로" 로 이미지 경로를 불러온다.

  • width = "px" 로 이미지의 가로 길이를 설정할 수 있다.

about_me.html

<!DOCTYPE html>
<html>
    <head>
        <title>상만두의 웹사이트</title>
    </head>
    <body>
        <nav>
            <a href="./index.html">Home</a>
            <a href="./blog_list.html">Blog</a>
            <a href="./about_me.html">About me</a>
        </nav>

        <h1>About me</h1>
        <h2>장고 스터디 상민입니다.</h2>

        <p>HTML, CSS, JS, DJANGO로 웹사이트 만들기</p>
        <p>조성범 멍충이 황인태 바보 오형주 짱</p>
        <a href="index.html">첫 화면으로 가기</a>

        
        <img src="images/photo2.jpg" width="400px">
    </body>
</html>

HTML 스타일 입히기

<nav style="background-color: darkgreen; font-size: 150%; text-align: center; ">
            <a href="./index.html" style="color: white">Home</a>
            <a href="./blog_list.html" style="color: white">Blog</a>
            <a href="./about_me.html" style="color: white">About me</a>
</nav>

VSCode의 장점은 자동완성 뿐만 아니라 이런 색 시각화 기능도 제공한다는 것.

style

  • 태그 안에 입력할 수 있으며 크기나 색, 위치 등을 정의할 수 있다.

    • font-size : 글씨 크기

    • color : 글씨 색깔

    • text-aligh : 정렬

여기서 문제는, 각 태그마다 스타일을 지정해야 한다는 것이다. 50개의 태그가 있으면 50개의 태그 안에 style 을 명시해야 한다.

이러한 문제는 <head> 태그에 style 을 정의함으로써 해결할 수 있다.

    <head>
        <title>상만두의 웹사이트</title>
        <style>
            nav {background-color: darkgreen; font-size: 150%; text-align: center;}
            nav a {color: gold}
        </style>
    </head>

두번째 문제가 있다. 네비게이션 바는 보통 각 페이지마다 동일하다. 따라서 <head> 에서 정의해주는 style을 각 html 파일마다 붙여넣어야 된다는 문제가 있다. html 파일이 100개면 어떻게 할것인가?

이를 CSS 파일을 이용해서 해결한다. 이 부분은 다음 챕터에서 다룬다.

이제 지금까지 작성한 파일을 업로드 하려고 한다.

  • pwd : 현재 위치하는 디렉토리를 보여준다.

  • cd : 현재 디렉토리를 변경한다.

    • 이 때, cd do 까지만 입력하고 tab을 누르면 디렉토리에 존재하는 파일이나 폴더 이름이 자동완성 된다.

  • ls : 현재 디렉토리에 있는 파일과 폴더를 보여준다

    • -A : 숨김 파일까지 볼 수 있다.

현재는 원격 저장소에 아무 것도 없는 모습. 이제 업로드 시작.

  • git add : commit할 변경사항(파일이나 폴더)들을 등록한다.

    • git add filename 으로 등록하며 모든 변경사항을 등록할 때는 git add . 로 입력한다.

  • git commit : add된 변경사항들을 commit 한다.

깃허브에 업로드 하기 위해 add -> commit -> push 단계를 거치는데, 왜 바로 push 하지 않고 이러한 단계를 거치는지에 대한 의문점을 가질 수 있다.

간단하게 정리하면 다음과 같다.

  • 내가 작성한 모든 파일을 깃허브에 올리고 싶지 않고 선택적으로 올리고 싶기 때문에 add 를 사용한다.

  • 로컬 저장소에서 내가 작성한 파일을 수정할 때 수정 내용을 메모할 수 있다. 또, 수정 과정을 매번 담을 수 있어서 에러가 났거나 예전 코드로 돌아가야 할 때 백업할 수 있다. 이럴 때 commit 을 사용한다.

원격 저장소에 업로드 된 모습.

CSS

practice.css

nav {background-color: darkgreen; font-size: 150%; text-align: center;}
nav a {color: red}

css 파일을 만들고, 각각의 html 파일이 css파일을 참조한다고만 명시하면 된다.

    <head>
        <title>상만두의 웹사이트</title>
        <link href="practice.css" rel="stylesheet" type="text/css">
    </head>

이렇게 하면 css 파일만을 수정해도 각각의 html 파일의 스타일이 변경되는 모습을 볼 수 있다.

JS 기초

자바스크립트는 활용도가 굉장히 높다. 자바스크립트를 사용하려면 head 태그에 script 태그를 추가하면 된다. 우선 이를 활용하기 위해 body 태그에 다음을 추가한다.

        <label for="inputA">a</label>
        <input id=inputA value=1 onkeyup="doSomething()">

        <label for="inputB">b</label>
        <input id=inputB value=2 onkeyup="doSomething()">

<label>

  • 간단한 텍스트 상자

  • for : 지정한 id의 태그와 연결할 수 있다

<input>

  • 사용자가 입력할 수 있는 공간

  • id : id를 설정한다. 태그마다 id가 존재할 수 있으며 이 id는 html 태그 내부에서 유일해야 한다.

  • onkeyup : 키보드의 키를 누르고 뗄 때 어떠한 동작을 하라는 의미

    • 여기서는 doSomething 이라는 함수가 실행된다.

이후, 스크립트 언어를 작성한다.

        <script type="text/javascript">
            function doSomething(){
                alert("Hello World!");
            }
        </script>

alert

  • 메시지를 팝업 형태로 출력한다.

        <script type="text/javascript">
            function doSomething(){
                let a = document.getElementById("inputA").value;
                let b = document.getElementById("inputB").value;
                document.getElementById("valueA").innerHTML = a;
                document.getElementById("valueB").innerHTML = b;
                document.getElementById("valueC").innerHTML = a + b;
            }
        </script>

document

  • 현재 코드가 작성되고 있는 문서를 의미한다.

getElementById

  • 해당 Id 값에 해당하는 태그의 값을 가져오라는 의미

  • 여기에서는 <input id=inputA" value=1 onkeyup="doSomething()"> 에 있는 value 값을 가지고 오게 된다.

let a

  • 스크립트에서는 변수 선언을 let 변수이름 형태로 한다.

innerHTML

  • 얻은 요소에 해당하는 값을 바꾸라는 의미이다.

  • document.getElementById("valueA").innerHTML = a; 여기서는 아이디가 valueA에 해당하는 요소의 값이 a로 변경되게 된다.

여기서 문제가 있는데 바로 마지막 줄 document.getElementById("valueC").innerHTML = a + b; 이다. a+b 를 string 형태로 보기 때문에 3 + 5 = 8 이 아닌 35로 출력하게 된다. 따라서 형변환을 해줘야 한다.

document.getElementById("valueC").innerHTML = Number(a) + Number(b);

다음과 같이 입력되는 모습

        <label for="inputA">a</label>
        <input id=inputA value=1 onkeyup="doSomething()">

        <label for="inputB">b</label>
        <input id=inputB value=2 onkeyup="doSomething()">

        <p>
            <span id="valueA">1</span> + <span id="valueB">2</span> = <span id="valueC">3</span>
        </p>

span

  • 어떤 영역을 지정할 때 사용한다.

또한, 실행이 잘 안될때에는 개발자 도구에서 확인할 수 있다.

코드에서 특정 라인에서 에러가 났다고 출력해주는 모습.

JS 파일로 관리하기

버튼을 누르면 현재 시간을 알려주는 페이지를 만드려고 한다. 이 때 CSS 파일처럼 JS도 파일로 가지고 있고 HTML 파일에서 불러올 수 있다.

    <head>
        <title>상만두의 웹사이트</title>
        <link href="practice.css" rel="stylesheet" type="text/css">

        <script type="text/javascript" src="add_two_numbers.js"></script>
        <script type="text/javascript" src="what_time_is_it.js"></script>
        
    </head>

add_two_numbers.js

function doSomething(){
    let a = document.getElementById("inputA").value;
    let b = document.getElementById("inputB").value;
    document.getElementById("valueA").innerHTML = a;
    document.getElementById("valueB").innerHTML = b;
    document.getElementById("valueC").innerHTML = Number(a) + Number(b);
}

what_time_is_it.js

function whatTimeIsIt(){
    alert(new Date())
}

위와같이 SSH Key가 존재하지 않는다고 뜬다. 이를 위해 CMDer에서 SSH Key를 생성한다. 키 생성 과정은 를 참고했다.

여기