[스파르타코딩클럽] 웹개발 종합반 1주차

MOON·2021년 11월 18일
0
post-thumbnail

웹개발 종합반 1주차

📝배운것

  • 서버/클라이언트/웹의 동작 개념
  • HTML, CSS, JS 기초 지식
  • 부트스트랩 적용

✏️웹서비스 동작 원리

브라우저가 서버에 요청을 보내고 서버로부터 결과물을 받아서 화면에 보여준다.

요청을 어디에 보내는가?

서버가 만들어 놓은 "API"라는 창구에 미리 정해진 약속대로 요청을 보내는 것

예) https://naver.com/
→ 이것은 "naver.com"이라는 이름의 서버에 있는, "/" 창구에 요청을 보낸 것!

  • HTML (파일)을 받는 경우

  • JSON (데이터)을 받는 경우

✏️HTML 기초

HTML은 뼈대, CSS는 꾸미기

  • HTML은 크게 head와 body로 구성되며, head안에는 페이지의 속성 정보를, body안에는 페이지의 내용을 담습니다.
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>스파르타코딩클럽 | HTML 기초</title>
</head>

<body>
    <!-- 구역을 나누는 태그들 -->
    <div>나는 구역을 나누죠</div>
    <p>나는 문단이에요</p>
    <ul>
        <li> bullet point!1 </li>
        <li> bullet point!2 </li>
    </ul>

    <!-- 구역 내 콘텐츠 태그들 -->
    <h1>h1은 제목을 나타내는 태그입니다. 페이지마다 하나씩 꼭 써주는 게 좋아요. 그래야 구글 검색이 잘 되거든요.</h1>
    <h2>h2는 소제목입니다.</h2>
    <h3>h3~h6도 각자의 역할이 있죠. 비중은 작지만..</h3>
    <hr>
    span 태그입니다: 특정 <span style="color:red">글자</span>를 꾸밀 때 써요
    <hr>
    a 태그입니다: <a href="http://naver.com/"> 하이퍼링크 </a>
    <hr>
    img 태그입니다: <img src="https://www.google.com/images/branding/googlelogo/1x/googlelogo_color_272x92dp.png" />
    <hr>
    input 태그입니다: <input type="text" />
    <hr>
    button 태그입니다: <button> 버튼입니다</button>
    <hr>
    textarea 태그입니다: <textarea>나는 무엇일까요?</textarea>
</body>

</html>

✏️CSS 기초

html 태그는, "누가 누구 안에 있느냐"를 이해하는 것이 가장 중요합니다. 나를 감싸고 있는 태그가 바뀌면, 그 안의 내용물도 모두 영향을 받지요!

# 배경관련
background-color
background-image
background-size

# 사이즈
width
height

# 폰트
font-size
font-weight
font-famliy
color

# 간격
margin
padding

연습 - 로그인 페이지 만들기

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>로그인페이지</title>
</head>
<style>
    .wrap {
        width: 400px;
        margin: auto;
    }

    .mytitle {
        color: white;
        width: 300px;
        height: 200px;

        /*3줄이 항상 같이 다닌다고 생각*/
        background-image: url("https://www.ancient-origins.net/sites/default/files/field/image/Agesilaus-II-cover.jpg");
        background-position: center;
        background-size: cover;

        border-radius: 10px;
        text-align: center;
        padding-top: 40px;
    }

    .mybtn {
        padding: 5px;
    }
</style>
<body>
<div class="wrap">
    <div class="mytitle">
        <h1>로그인 페이지</h1>
        <h5>아이디, 비밀번호를 입력해주세요</h5>
    </div>
    <div>
        <p>
            ID: <input type="text">
        </p>
        <p>
            PW: <input type="password">
        </p>
    </div>
    <button class="mybtn">로그인하기</button>
</div>
</body>
</html>

실행결과

✏️폰트, 주석, 파일분리

구글웹폰트 적용

https://fonts.google.com/?subset=korean

  • 코드 추가
<!-- HTML에 이 부분을 추가하고 -->
<link href="https://fonts.googleapis.com/css2?family=Nanum+Gothic&display=swap" rel="stylesheet">
/* CSS에 이 부분을 추가하면 완성! */
* {
	font-family: 'Nanum Gothic', sans-serif;
}

주석달기

👉 주석은 언제 사용하나요?
1) 필요없어진 코드를 삭제하는 대신 임시로 작동하지 못하게 하고 싶을 때
2) 코드에 대한 간단한 설명을 붙여두고 싶을 때 사용합니다.

주석을 붙여놓으면, 브라우저/컴퓨터가 읽지 않아요.
즉, 개발자 본인 또는 동료를 위해 붙여두는 것!

CSS 파일분리

<!-- style.css 파일을 같은 폴더에 만들고, head 태그에서 불러오기 -->
<link rel="stylesheet" type="text/css" href = "(css파일이름).css">

✏️부트스트랩 적용

남이 미리 작성한 CSS를 내 HTML 파일에 적용한다는 점에서, bootstrap 적용은 CSS 파일 분리와 원리가 동일합니다.
다만, CSS의 파일이 인터넷 어딘가에 있다는 점이 다를 뿐입니다.

부트스트랩 컴포넌트

https://getbootstrap.com/docs/4.0/components/alerts/

연습 - 나홀로메모장 만들기

<!doctype html>
<html lang="en">

<head>
    <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">

    <!-- Bootstrap CSS -->
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css"
          integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">

    <!-- Optional JavaScript -->
    <!-- jQuery first, then Popper.js, then Bootstrap JS -->
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js"
            integrity="sha384-ApNbgh9B+Y1QKtv3Rn7W3mgPxhU9K/ScQsAP7hUibX39j7fakFPskvXusvfa0b4Q"
            crossorigin="anonymous"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js"
            integrity="sha384-JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl"
            crossorigin="anonymous"></script>

    <!-- google font -->
    <link href="https://fonts.googleapis.com/css2?family=Jua&display=swap" rel="stylesheet">

    <title>스파르타코딩클럽 | 부트스트랩 연습하기</title>

    <style>
        * {
            font-family: 'Jua', sans-serif;
        }

        .wrap {
            width: 900px;
            margin: auto;
        }

        .posting-box {
            width: 400px;
            margin: 10px auto 25px;
            border: 1px solid black;
            border-radius: 10px;

            padding: 30px;
        }

        .comment {
            color: blue;
            font-weight: bold;
        }
    </style>

</head>

<body>
<div class="wrap">
    <div class="jumbotron">
        <h1 class="display-4">나홀로 링크 메모장</h1>
        <p class="lead">중요한 링크를 저장해두고, 나중에 볼 수 있는 공간입니다.</p>
        <hr class="my-4">
        <p class="lead">
            <a class="btn btn-primary btn-lg" href="#" role="button">포스팅박스 열기</a>
        </p>
    </div>
    <form class="posting-box">
      <div>
        <label for="exampleInputEmail1">아티클 URL</label>
        <input type="email" class="form-control" id="exampleInputEmail1" aria-describedby="emailHelp">
        <p></p>
      </div>
      <div class="form-group">
        <label for="exampleFormControlTextarea1">간단 코멘트</label>
        <textarea class="form-control" id="exampleFormControlTextarea1" rows="3"></textarea>
      </div>
      <button type="submit" class="btn btn-primary">기사저장</button>
    </form>
    <div class="card-columns">
        <div class="card">
            <img class="card-img-top"
                 src="https://image.theminda.com/data/tg/image/tour/middle/201905/c8aee858ed6e8c34010fe3c4ae9be8a5.jpg"
                 alt="Card image cap">
            <div class="card-body">
                <a href="www.naver.com"> 여기 기사 제목이 들어가죠</a>
                <p class="card-text">기사의 요약 내용이 들어갑니다. 동해물과 백두산이 마르고 닳도록 하느님이 보우하사 우리나라만세 무궁화 삼천리 화려강산...</p>
                <p class="card-text comment">여기에 코멘트가 들어갑니다.</p>
            </div>
        </div>

    </div>
</div>
</body>

</html>

결과

✏️JS 기초

프로그래밍 언어 중 하나로, 브라우저가 알아들을 수 있는 언어입니다.

  • Q. 왜 브라우저는 Javascript만 알아들어요? HTML안에다 파이썬, Java 같은 언어를 써서 주면 안되나요?

  • A. 불가능한 이야기는 아닙니다. 다만, 이 "역사적인 이유 & 이미 만들어진 표준"이기 때문에, 모든 브라우저는 기본적으로 Javascript를 알아듣게 설계되어있고, 모든 웹서버는 HTML+CSS+Javascript를 주게 되어있죠.

리스트 & 딕셔너리

  • 리스트
let a_list = []  // 리스트를 선언. 변수 이름은 역시 아무렇게나 가능!

// 또는,

let b_list = [1,2,'hey',3] // 로 선언 가능

b_list[1] // 2 를 출력
b_list[2] // 'hey'를 출력

// 리스트에 요소 넣기
b_list.push('헤이')
b_list // [1, 2, "hey", 3, "헤이"] 를 출력

// 리스트의 길이 구하기
b_list.length // 5를 출력
  • 딕셔너리
let a_dict = {}  // 딕셔너리 선언. 변수 이름은 역시 아무렇게나 가능!

// 또는,

let b_dict = {'name':'Bob','age':21} // 로 선언 가능
b_dict['name'] // 'Bob'을 출력
b_dict['age'] // 21을 출력

b_dict['height'] = 180 // 딕셔너리에 키:밸류 넣기
b_dict // {name: "Bob", age: 21, height: 180}을 출력
  • 리스트와 딕셔너리 조합
names = [{'name':'bob','age':20},{'name':'carry','age':38}]

// names[0]['name']의 값은? 'bob'
// names[1]['name']의 값은? 'carry'

new_name = {'name':'john','age':7}
names.push(new_name)

// names의 값은? [{'name':'bob','age':20},{'name':'carry','age':38},{'name':'john','age':7}]
// names[2]['name']의 값은? 'john'

필요한 이유

💡 순서를 표시할 수 있고, 정보를 묶을 수 있습니다.

앞에서 언급한 <스파르타과일가게>가 정말 잘 되어서 전국에서 손님이 찾아오고 있습니다. 대기표를 작성하기 위해서 온 순서대로 이름, 휴대폰 번호를 적도록 하였는데요. 변수만을 사용한 모습은 다음과 같습니다.

let customer_1_name = '김스파';
let customer_1_phone = '010-1234-1234';
let customer_2_name = '박르탄';
let customer_2_phone = '010-4321-4321';
...(알아보기 힘듭니다.)

👉딕셔너리를 활용한다면 다음과 같이 고객 별로 정보를 묶을 수 있습니다.
let customer_1 = {'name': '김스파', 'phone': '010-1234-1234'};
let customer_2 = {'name': '박르탄', 'phone': '010-4321-4321'};

👉그리고 순서를 나타내기 위해 리스트를 사용하면, 이렇게나 깔끔해집니다.
let customer = [
{'name': '김스파', 'phone': '010-1234-1234'},
{'name': '박르탄', 'phone': '010-4321-4321'}
]

✅보기에도 깔끔해지고, 다루기도 쉬워지고, 고객이 새로 한 명 더 오더라도 .push 함수를 이용해 간단하게 대응할 수 있습니다.

패턴 연습

  • 미세먼지의 값이 40 미만인 구 이름과 값을 출력
for (let i = 0; i < mise_list.length; i++){
    let gu_name = mise_list[i]['MSRSTE_NM']
    let gu_mise = mise_list[i]['IDEX_MVL']
    
    if (gu_mise < 40)
      console.log(gu_name, gu_mise)
}

결과

중구 31
VM531:5 종로구 39
VM531:5 용산구 -99
VM531:5 서대문구 37
VM531:5 마포구 36
VM531:5 광진구 31
VM531:5 성동구 33
VM531:5 중랑구 34
VM531:5 동대문구 34
VM531:5 성북구 37
VM531:5 강북구 39
VM531:5 노원구 36
VM531:5 구로구 37
VM531:5 관악구 37
VM531:5 양천구 -99
VM531:5 강남구 39
VM531:5 강동구 39
  • 자전거가 5개 이하인 정류장의 이름을 출력하기
for (let i= 0; i < bikes.length; i++){
    let stationName = bikes[i]['stationName']
    let bikeCnt = bikes[i]['parkingBikeTotCnt']
    
    if(bikeCnt <= 5){
    	console.log(stationName);
    }
}

결과

101. (구)합정동 주민센터
VM650:6 105. 합정역 5번출구 앞
VM650:6 107. 신한은행 서교동금융센터점 앞
VM650:6 115. 사루비아 빌딩 앞
VM650:6 116. 일진아이윌아파트 옆
VM650:6 120. 신수동 사거리
VM650:6 136. 대흥동 주민센터
VM650:6 137. NH농협 신촌지점 앞
VM650:6 142. 아현역 4번출구 앞
VM650:6 147. 마포역 4번출구 뒤
VM650:6 157. 애오개역 4번출구 앞
VM650:6 158. 독립문 어린이 공원
VM650:6 159. 이대역 4번 출구
VM650:6 161. 무악재역1번 출구
VM650:6 163. 명지전문대학교 정문 앞
VM650:6 173. 서대문역 8번출구 앞
VM650:6 176. 명지대학교 도서관
VM650:6 177. 북가좌 초등학교
VM650:6 178. 증산3교 앞
VM650:6 184. SK망원동주유소 건너편
VM650:6 185. 마포 신수공원 앞
VM650:6 188. 홍은동 정원여중 입구
VM650:6 192. 연서어린이공원
VM650:6 194. 증산교 앞
VM650:6 196. 연희교차로 인근
VM650:6 211. 여의도역 4번출구 옆

0개의 댓글