[스파르타코딩클럽] 웹개발 종합반 - 1주차 개발일지+수강후기

권혁준·2022년 2월 27일
0

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

HTML을 받는 경우
웹페이지는 서버에서 미리 준비해두었던 것을 받아서 그려주는 것
1. API로 요청
2. 받은 HTML 파일을 그려줌

데이터만 받는 경우
JSON형식으로 데이터 받음

⭐️ JSON형식JavaScript Object Notation
Javascript 객체 문법으로 구조화된 데이터를 표현하기 위한 문자 기반의 표준 포맷입니다. 웹 어플리케이텍스트션에서 데이터를 전송할 때 일반적으로 사용

2. HTML과 CSS

(1)HTML과 CSS 개념

⭐️ HTML은 뼈대, CSS는 꾸미기!

HTML Hyper Text Markup Language

  • 구역과 텍스트를 나타내는 코드

CSS Cascading Style Sheets

  • HTML로 나타낸 구역을 꾸며주는 것
  • HTML 내 style 속성으로 꾸미기 가능
  • HTML 코드 내에 CSS 파일을 불러와서 적용
ex) 
1️⃣ styles.css 파일에 @import "settings.css";하여 파일 불러오기
2️⃣ HTML에서 <link rel="stylesheet" href="styles.css"/>하여 파일 적용

(2) HTML 기초

HTML은 크게 head와 body로 구성
head안에는 페이지의 속성 정보

<!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안에는 페이지의 내용

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

(3) CSS 기초

✅ html 태그는 HTML 부모-자식 구조를 이해가 가장 중요
✅ 구성하는 태그가 바뀌면 그 안의 내용물에 모두 영향

css는 head 안에 style로 공간을 만들어 작성

⭐️ CSS 사용방법
mytitle라는 클래스를 꾸며줄 때 .mytitle { ... } 라고 작성

ex)
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Login page</title>
    <link rel="preconnect" href="https://fonts.googleapis.com">
    <link href="https://fonts.googleapis.com/css2?family=Jua&display=swap" rel="stylesheet">
    <style>
        * {
            font-family: 'Jua', sans-serif;
        }
        .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;
        }

    </style>
</head>

4. JavaScript

(1) JavaScript란?

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

(2) JavaScript 기초

Javascript는 head 안에 script에서 작성

ex)
    <script>
        function hey() {
            alert('안녕!!');
        }
    </script>
<a onclick="hey()" class="btn btn-primary btn-lg" href="#" role="button">포스팅박스 열기</a>
=> onclick="hey()"로 위의 함수를 연결

(3) JavaScript 기본문법

1. 함수

  • 기본생김새
// 만들기
function 함수이름(필요한 변수들) {
내릴 명령들을 순차적으로 작성
}
// 사용하기
함수이름(필요한 변수들);
  • 예시
// 두 숫자를 입력받으면 더한 결과를 돌려주는 함수
function sum(num1, num2) {
	console.log('num1: ', num1, ', num2: ', num2);
	return num1 + num2;
}

sum(3, 5); // 8
sum(4, -1); // 3

2. 조건문

  • 20 보다 작으면 작다고, 크면 크다고 알려주는 함수
function is_adult(age){
	if(age > 20){
		alert('성인이에요')
	} else {
		alert('청소년이에요')
	}
}

is_adult(25)
  • if, else if, else if, else if else
function is_adult(age){
	if(age > 20){
		alert('성인이에요')
	} else if (age > 10) {
		alert('청소년이에요')
	} else {
		alert('10살 이하!')
	}
}

is_adult(12)
  • AND 조건과 OR 조건!
// AND 조건은 이렇게
function is_adult(age, sex){
	if(age > 20 && sex == '여'){
		alert('성인 여성')
	} else if (age > 20 && sex == '남') {
		alert('성인 남성')
	} else {
		alert('청소년이에요')
	}
}

// 참고: OR 조건은 이렇게
function is_adult(age, sex){
	if (age > 65 || age < 10) {
		alert('탑승하실 수 없습니다')
	} else if(age > 20 && sex == '여'){
		alert('성인 여성')
	} else if (age > 20 && sex == '남') {
		alert('성인 남성')
	} else {
		alert('청소년이에요')
	}
}

is_adult(25,'남')

3. 반복문

for (let i = 0; i < 100; i++) {
	console.log(i);
}
for (1. 시작조건; 2. 반복조건; 3. 더하기) {
	4. 매번실행
}

1 -> 2체크하고 -> (괜찮으면) -> 4 -> 3
-> 2체크하고 -> (괜찮으면) -> 4 -> 3
-> 2체크하고 -> (괜찮으면) -> 4 -> 3
-> 2체크하고 -> (괜찮으면) -> 4 -> 3

와 같은 순서로 실행됩니다.
i가 증가하다가 반복조건에 맞지 않으면, 반복을 종료하고 빠져나옵니다.

⭐️ 문법을 외우는 것보다 짜임새나 구조를 이해하는 게 중요!

1주차 숙제 : 원페이지 쇼핑몰 HTML+CSS 만들기

1) 문제

아래 기획서를 보고, 부트스트랩 또는 템플릿을 활용해서 나만의쇼핑몰의 메인 페이지를 완성해주세요.

기능: 주문하기 버튼을 클릭했을 때 '주문이 완료되었습니다.'라는 얼럿을 띄워주세요.

2) 나의 풀이

<!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 href="<link href="https://fonts.googleapis.com/css2?family=Noto+Sans+KR&display=swap" rel="stylesheet">

    <style>
        * {
            font-family: 'Noto Sans KR', sans-serif;
        }

        .item-page {
            width: 502px;
            height: 734px;
            margin: auto;
            margin-top: 16px;
            border: 1px solid black;
        }

        .item-image {
            background-color: green;
            width: 450px;
            height: 300px;
            background-image: url("https://post-phinf.pstatic.net/MjAyMTEwMjJfODUg/MDAxNjM0ODcwNjg5Mzc2.n7nH7taibbSgR5BvAijbRzeuUyBS5DnTX2eZIkgp8mog.gUpqOjxlRzaIqB2Yyc5_m7jfFp2Ya45ux3xCkpUNDdEg.JPEG/Screenshot_2021-10-22_at_10.22.00.jpg?type=w1200");
            background-size: cover;
            background-position: center;
            margin: auto;
            margin-top: 16px;
        }

        .item-info {
            width: 450px;
            margin: 16px 25px;
        }

        .item-info i {
            color: red;
            font-weight: bold;
        }

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

        .item-price {
            font-size: 20px;
            color: tomato;
            margin-left: 20px;
        }

        .item-order {
            width: 450px;
            margin: 0px 25px 16px 25px;
        }

        .item-order-btn {
            margin: auto;
            display: block;
        }
    </style>

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

</head>

    <body>
        <div class="item-page">
            <div class="item-image"></div>
            <div class="item-info">
                <i>NEW</i>
                <h1 class="item-title">Sony A7IV ILCE-7M4<span class="item-price">3,360,530원</span></h1>
                <p>오늘날의 크리에이터들을 위한 풀프레임 미러리스, a7IV입니다. 풀프레임 베스트셀러 a7의 4세대 바디로서 카메라의 표준을 새로이 제시합니다.</p>
            </div>
            <div class="item-order">
                <div class="input-group mb-3">
                    <div class="input-group-prepend">
                        <span class="input-group-text" id="inputGroup-sizing-default">주문자 이름</span>
                    </div>
                    <input type="text" class="form-control" aria-label="Default"
                           aria-describedby="inputGroup-sizing-default">
                </div>
                <div class="input-group mb-3">
                    <div class="input-group-prepend">
                        <label class="input-group-text" for="inputGroupSelect01">수량</label>
                    </div>
                    <select class="custom-select" id="inputGroupSelect01">
                        <option selected>-- 수량을 선택하세요 --</option>
                        <option value="1">1</option>
                        <option value="2">2</option>
                        <option value="3">3</option>
                    </select>
                </div>
                <div class="input-group mb-3">
                    <div class="input-group-prepend">
                        <span class="input-group-text" id="inputGroup-sizing-default">주소</span>
                    </div>
                    <input type="text" class="form-control" aria-label="Default"
                           aria-describedby="inputGroup-sizing-default">
                </div>
                <div class="input-group mb-3">
                    <div class="input-group-prepend">
                        <span class="input-group-text" id="inputGroup-sizing-default">전화번호</span>
                    </div>
                    <input type="text" class="form-control" aria-label="Default"
                           aria-describedby="inputGroup-sizing-default">
                </div>
                <button onclick="hey()" type="button" class="btn btn-primary item-order-btn">주문하기</button>
            </div>
        </div>
    </body>

</html>

3) 완성 화면

profile
비전공개발자의 개발일지

0개의 댓글

관련 채용 정보