*/스파르타코딩클럽 웹개발종합반

[스파르타코딩클럽 | 웹개발종합반] 1주차: HTML / CSS / JavaScript

sssbin 2021. 9. 12. 23:59

1. 서버/클라이언트/웹의 동작 개념

   - 브라우저

     1) API로 요청을 보냄

     2) 받은 HTML 파일 나타냄

HTML : 뼈대   CSS : 꾸며주는 것(디자인)   Javascript : 움직이는 것(액션)

 

2. HTML, CSS

 

   - HTML: 구역과 텍스트를 나타내는 코드

         ㄴ 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 내 style 속성으로 꾸미기 가능 → 이를 모아 CSS 파일

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title> 로그인페이지 </title>
    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=East+Sea+Dokdo&display=swap" rel="stylesheet">
    <style>
        * {
            font-family: 'East Sea Dokdo', cursive;
        }
        .mytitle {
            background-color : green;

            width : 300px;
            height: 200px;

            color : white;
            text-align : center;

            background-image : url("https://www.ancient-origins.net/sites/default/files/field/image/Agesilaus-II-cover.jpg");
            background-size : cover;
            background-position : center;

            border-radius : 10px;

            padding-top : 20px;
        }
        .wrap {
            width : 300px;
            margin : auto;
        }
        .mybtn {
            width : 100px;
            margin : auto;
            display : block;
        }
        .login {
            display : block;
            width : 200px;
            margin : auto;
        }
    </style>
</head>
<body>
    <div class="wrap">
        <div class="mytitle">
            <h1> 로그인 페이지</h1>
            <h5> 아이디, 패스워드를 입력해주세요. </h5>
        </div>

        <div class="login">
            <p> ID: <input type="text" /> </p>
            <p> PW: <input type="text" /> </p>
        </div>

        <button class="mybtn"> 로그인하기 </button>
    </div>
</body>
</html>

   * 폰트 : https://fonts.google.com/?subset=korean 

   * 컨트롤+슬래시 → 주석 처리

   * HTML/CSS 파일 분리 → css 파일을 같은 폴더에 만들고 head 태그에서 불러오기

                                            <link rel="stylesheet" type="text/css" href = "(css파일이름).css">

 

3. Bootstrap

https://getbootstrap.com/docs/5.0/getting-started/introduction/

<!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>

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

    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=Stylish&display=swap" rel="stylesheet">


    <style>
        * {
            font-family: 'Stylish', sans-serif;
        }
        .wrap {
            width : 880px;
            margin : auto;
        }
        .comment {
            color : blue;
            font-weight : bold;
        }
        .posting-box {
            width : 500px;
            margin : 0px auto 20px auto;
            padding : 50px;
            border : 2px solid black;
            border-radius : 5px;
        }
    </style>

    <script>
        function hey() {
            alert('안녕!!');
        }
    </script>
</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 onclick="hey()" class="btn btn-primary btn-lg" href="#" role="button">포스팅 박스 열기</a>
        </p>
    </div>
        <div class="posting-box">
            <div class="form-group">
                <label for="exampleInputEmail1">아티클 URL</label>
                <input type="email" class="form-control" id="exampleInputEmail1" aria-describedby="emailHelp">
                <small id="emailHelp" class="form-text text-muted"> </small>
            </div>
            <div class="form-group">
                <label for="exampleInputPassword1">간단 코멘트</label>
                <textarea class="form-control" id="exampleInputPassword1" rows="3"> </textarea>
            </div>
            <button type="submit" class="btn btn-primary">기사저장</button>
        </div>


        <div class="card-columns">
            <div class="card">
                <img class="card-img-top" src=https://www.eurail.com/content/dam/images/eurail/Italy%20OCP%20Promo%20Block.adaptive.767.1535627244182.jpg alt="Card image cap">
                <div class="card-body">
                    <a class="card-title" href="http://naver.com/"> 여기 기사 제목이 들어가죠 </a>
                    <p class="card-text">기사의 요약 내용이 들어갑니다. 동해물과 백두산이 마르고 닳도록 하느님이 보우하사 우리나라만세 무궁화 삼천리 화려강산...</p>
                    <p class="card-text comment"> 여기에 코멘트가 들어갑니다. </p>
                </div>
            </div>
            <div class="card">
                <img class="card-img-top" src=https://www.eurail.com/content/dam/images/eurail/Italy%20OCP%20Promo%20Block.adaptive.767.1535627244182.jpg alt="Card image cap">
                <div class="card-body">
                    <a class="card-title" href="http://naver.com/"> 여기 기사 제목이 들어가죠 </a>
                    <p class="card-text">기사의 요약 내용이 들어갑니다. 동해물과 백두산이 마르고 닳도록 하느님이 보우하사 우리나라만세 무궁화 삼천리 화려강산...</p>
                    <p class="card-text comment"> 여기에 코멘트가 들어갑니다. </p>
                </div>
            </div>
            <div class="card">
                <img class="card-img-top" src=https://www.eurail.com/content/dam/images/eurail/Italy%20OCP%20Promo%20Block.adaptive.767.1535627244182.jpg alt="Card image cap">
                <div class="card-body">
                    <a class="card-title" href="http://naver.com/"> 여기 기사 제목이 들어가죠 </a>
                    <p class="card-text">기사의 요약 내용이 들어갑니다. 동해물과 백두산이 마르고 닳도록 하느님이 보우하사 우리나라만세 무궁화 삼천리 화려강산...</p>
                    <p class="card-text comment"> 여기에 코멘트가 들어갑니다. </p>
                </div>
            </div>
            <div class="card">
                <img class="card-img-top" src=https://www.eurail.com/content/dam/images/eurail/Italy%20OCP%20Promo%20Block.adaptive.767.1535627244182.jpg alt="Card image cap">
                <div class="card-body">
                    <a class="card-title" href="http://naver.com/"> 여기 기사 제목이 들어가죠 </a>
                    <p class="card-text">기사의 요약 내용이 들어갑니다. 동해물과 백두산이 마르고 닳도록 하느님이 보우하사 우리나라만세 무궁화 삼천리 화려강산...</p>
                    <p class="card-text comment"> 여기에 코멘트가 들어갑니다. </p>
                </div>
            </div>
            <div class="card">
                <img class="card-img-top" src=https://www.eurail.com/content/dam/images/eurail/Italy%20OCP%20Promo%20Block.adaptive.767.1535627244182.jpg alt="Card image cap">
                <div class="card-body">
                    <a class="card-title" href="http://naver.com/"> 여기 기사 제목이 들어가죠 </a>
                    <p class="card-text">기사의 요약 내용이 들어갑니다. 동해물과 백두산이 마르고 닳도록 하느님이 보우하사 우리나라만세 무궁화 삼천리 화려강산...</p>
                    <p class="card-text comment"> 여기에 코멘트가 들어갑니다. </p>
                </div>
            </div>
            <div class="card">
                <img class="card-img-top" src=https://www.eurail.com/content/dam/images/eurail/Italy%20OCP%20Promo%20Block.adaptive.767.1535627244182.jpg alt="Card image cap">
                <div class="card-body">
                    <a class="card-title" href="http://naver.com/"> 여기 기사 제목이 들어가죠 </a>
                    <p class="card-text">기사의 요약 내용이 들어갑니다. 동해물과 백두산이 마르고 닳도록 하느님이 보우하사 우리나라만세 무궁화 삼천리 화려강산...</p>
                    <p class="card-text comment"> 여기에 코멘트가 들어갑니다. </p>
                </div>
            </div>
        </div>
    </div>
</body>

</html>

  • 포스팅 박스 열기 → '안녕!!' 경고 알림창 뜸
  • 여기 기사 제목이 들어가죠 → 네이버로 연결

 

4. Javascript

 

// 변수, 자료형, 함수, 조건문, 반복문

// alert

// console.log

 

   1) 변수(숫자, 문자열) 및 자료형 

      - let

           >> let first_name = 'subin'

           >> let last_name = 'lim'

           >> first_name + last_name

           >> 'subinlim'

      - 리스트 [], push/pop → 순서!!

           >> let a_list = ['수박', '참외', '배']

           >> a_list[0]

           << "수박"

           >> a_list.push('감')

           >> a_list[3]

           << "감"

      - 딕셔너리 {}, key:value

           >> let a_dict = {'name':'bob', 'age':27}

           >> a_dict['name']

           << "bob"

           >> a_dict['fruits'] = a_list

           >> a_dict

           << {name: "bob", age: 27, fruits: Array(4)}

      - split

           >> let myemail = 'sss@gmail.com'

           >> myemail.split('@')

           << ["sss", "gmail.com"]

           >> myemail.split('@')[1].split('.')

           >> a_dict

           << ["gmail", "com"]

 

 

   2) 함수

      - 만들기 → function

          function sum(num1, num2) {

                return num1+num2

          }

      - 사용하기

           >> sum(2,3)

           << 5

           >> let result = sum(2,3)

           >> result

           << 5

 

 

   3) 조건문

      - if / else if

      - and(&&) / or(||)

      - 예제

          >> function is_adult(age) {

                   if (age>20) {

                      alert('성인이에요')

 

                   }

 

                   else {

 

                      alert('청소년이에요')

 

                   }

 

               }

 

 

          >> is_adult(25)

               

   4) 반복문

      - 예제1

          for (let i=0; i<10; i++) {

                 console.log(i)

          }

      - 예제2

          let people = ['철수', '영희', '민수', '형준', '기남', '동희']

          for (let i=0; i<people.length; i++) {

                console.log(people[i])

          }

 

5. 숙제: 원페이지 쇼핑몰 HTML+CSS 만들기

<!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>

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

    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
    <link href="https://fonts.googleapis.com/css2?family=Song+Myung&family=Stylish&display=swap" rel="stylesheet">

    <style>
        * {
            font-family: 'Song Myung', serif;
            font-family: 'Stylish', sans-serif;
        }

        .photo {
            text-align : center;
        }

        .content_title {
            padding : 20px 300px 0px 300px;
        }

        .content_order {
            padding : 20px 500px 0px 300px;
        }

        .title {
            font-size : 50px;
            font-weight : bold;
        }

        .size {
            width : 200px;
            height : 20px;
            float : right;
        }

        .button {
            width : 200px;
            margin : auto;
            display : block;
        }
    </style>

    <script>
        function order() {
            alert('주문이 완료되었습니다.');
        }
    </script>
</head>

<body>
    <div>
        <div class="photo">
            <img src="http://swiki.cafe24.com/web/product/big/201808/653369f1193cfcf3d01894d870a6cd59.jpg" width="360px" height="320px"/>
        </div>

        <div class="content_title">
            <div>
                <span class="title"> 상품제목 </span> 가격: 10,000원 / 개
            </div>

            <div>
                집안을 밝게 비춰주는 형광등이 꺼지고, 방 안에 어둠이 내릴 때, 은은한 빛으로 따뜻하게 공간을 감싸주는 무드등 하나 만으로 집안 분위기가 바뀔 수 있다.
            </div>
        </div>

        <div class="content_order">
            <div class="title"> 주문하기 </div>

            <div>
                <label for="name"> 주문자 성함: </label>
                <input type="text" id="name" class="size" />
            </div>

            <div>
                <label for="number"> 수량: </label>
                <input class="size" list="datalistOptions" id="number" placeholder="수량을 입력하세요">
                <datalist id="datalistOptions" >
                    <option value="1">
                    <option value="2">
                    <option value="3">
                    <option value="4">
                    <option value="5">
                </datalist>
            </div>

            <div>
                <label for="address"> 주소: </label>
                <input type="text" id="address" class="size" />
            </div>

            <div>
                <label for="phone"> 전화번호: </label>
                <input type="tel" id="phone" class="size" />
            </div>
        </div>

        <div>
            <button onclick="order()" class="button"> 주문하기 </button>
        </div>
    </div>

</body>

</html>

기본화면

 

수량 선택
주문하기