1. spartaflix 만들기

spartaflix

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

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>스파르타플릭스</title>
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" rel="stylesheet"
        integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous">
    <style>
        @import url('https://fonts.googleapis.com/css2?family=Nanum+Myeongjo&display=swap');

        * {
            font-family: "Nanum Myeongjo", serif;
            font-weight: 400;
            font-style: normal;
        }

        .main {
            color: white;

            background-image: url('https://occ-0-1123-1217.1.nflxso.net/dnm/api/v6/6AYY37jfdO6hpXcMjf9Yu5cnmO0/AAAABeIfo7VL_VDyKnljV66IkR-4XLb6xpZqhpLSo3JUtbivnEW4s60PD27muH1mdaANM_8rGpgbm6L2oDgA_iELHZLZ2IQjG5lvp5d2.jpg?r=e6e.jpg');
            background-position: center;
            background-size: cover;
        }

        body {
            background-color: black;
        }

        .mycards {
            width: 1200px;
            margin: 20px auto 20px auto;
        }
        .mypostingbox {
            width: 500px;
            margin: 20px auto 20px auto;

            border: 1px solid white;
            border-radius: 5px;
            padding: 20px;
        }
        .form-floating > input {
            background-color: transparent;
            color: white;
        }
        .form-floating > label {
            color: white;
        }
        .input-group > label {
            background-color: transparent;
            color: white;
        }
        .mypostingbox > button {
            width: 100%;
        }
    </style>
</head>

<body>
    <header class="p-3 text-bg-dark">
        <div class="container">
            <div class="d-flex flex-wrap align-items-center justify-content-center justify-content-lg-start">
                <a href="/" class="d-flex align-items-center mb-2 mb-lg-0 text-white text-decoration-none">
                    <svg class="bi me-2" width="40" height="32" role="img" aria-label="Bootstrap">
                        <use xlink:href="#bootstrap"></use>
                    </svg>
                </a>

                <ul class="nav col-12 col-lg-auto me-lg-auto mb-2 justify-content-center mb-md-0">
                    <li><a href="#" class="nav-link px-2 text-danger">spartaflix</a></li>
                    <li><a href="#" class="nav-link px-2 text-white"></a></li>
                    <li><a href="#" class="nav-link px-2 text-white">시리즈</a></li>
                    <li><a href="#" class="nav-link px-2 text-white">영화</a></li>
                    <li><a href="#" class="nav-link px-2 text-white">내가 찜한 콘텐츠</a></li>
                </ul>

                <form class="col-12 col-lg-auto mb-3 mb-lg-0 me-lg-3" role="search">
                    <input type="search" class="form-control form-control-dark text-bg-dark" placeholder="Search..."
                        aria-label="Search">
                </form>

                <div class="text-end">
                    <button type="button" class="btn btn-outline-light me-2">Login</button>
                    <button type="button" class="btn btn-danger">Sign-up</button>
                </div>
            </div>
        </div>
    </header>
    <div class="main">
        <div class="p-5 mb-4 bg-body-tertiary rounded-3">
            <div class="container-fluid py-5">
                <h1 class="display-5 fw-bold">킹덤</h1>
                <p class="col-md-8 fs-4">병든 왕을 둘러싸고 흉흉한 소문이 떠돈다. 어둠에 뒤덮인 조선, 기이한 역병에 신음하는 산하. 정체 모를 악에 맞서 백성을 구원할 희망은 오직
                    세자뿐이다.</p>
                <button type="button" class="btn btn-outline-light">영화 기록하기</button>
                <button type="button" class="btn btn-outline-light">상세정보</button>
            </div>
        </div>
    </div>
    <div class="mypostingbox">
        <div class="form-floating mb-3">
            <input type="email" class="form-control" id="floatingInput" placeholder="영화 이미지">
            <label for="floatingInput">영화 이미지 주소</label>
        </div>
        <div class="form-floating mb-3">
            <input type="email" class="form-control" id="floatingInput" placeholder="영화 제목">
            <label for="floatingInput">영화 제목</label>
        </div>
        <div class="input-group mb-3">
            <label class="input-group-text" for="inputGroupSelect01">별점</label>
            <select class="form-select" id="inputGroupSelect01">
                <option selected>별점선택</option>
                <option value="1"></option>
                <option value="2">⭐⭐</option>
                <option value="3">⭐⭐⭐</option>
                <option value="4">⭐⭐⭐⭐</option>
                <option value="5">⭐⭐⭐⭐⭐</option>
            </select>
        </div>
        <div class="form-floating mb-3">
            <input type="email" class="form-control" id="floatingInput" placeholder="추천 이유">
            <label for="floatingInput">추천 이유</label>
        </div>
        <button type="button" class="btn btn-danger">기록하기</button>
    </div>
    <div class="mycards">
        <div class="row row-cols-1 row-cols-md-4 g-4">
            <div class="col">
                <div class="card h-100">
                    <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                        class="card-img-top" alt="...">
                    <div class="card-body">
                        <h5 class="card-title">영화 제목</h5>
                        <p class="card-text">⭐⭐⭐</p>
                        <p class="card-text">영화 코멘트</p>
                    </div>
                </div>
            </div>
            <div class="col">
                <div class="card h-100">
                    <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                        class="card-img-top" alt="...">
                    <div class="card-body">
                        <h5 class="card-title">영화 제목</h5>
                        <p class="card-text">⭐⭐⭐</p>
                        <p class="card-text">영화 코멘트</p>
                    </div>
                </div>
            </div>
            <div class="col">
                <div class="card h-100">
                    <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                        class="card-img-top" alt="...">
                    <div class="card-body">
                        <h5 class="card-title">영화 제목</h5>
                        <p class="card-text">⭐⭐⭐</p>
                        <p class="card-text">영화 코멘트</p>
                    </div>
                </div>
            </div>
            <div class="col">
                <div class="card h-100">
                    <img src="https://movie-phinf.pstatic.net/20210728_221/1627440327667GyoYj_JPEG/movie_image.jpg"
                        class="card-img-top" alt="...">
                    <div class="card-body">
                        <h5 class="card-title">영화 제목</h5>
                        <p class="card-text">⭐⭐⭐</p>
                        <p class="card-text">영화 코멘트</p>
                    </div>
                </div>
            </div>

        </div>
    </div>

</body>

</html>



2. Javascript 기초, 자료형

변수: 데이터를 저장하는 공간 (let)


console-log-hello

let a = 'hello';
console.log(a);


console-log-hello-안녕

let a = 'hello';
let b = '안녕';
console.log(a+b);


console-log-5-3

let a = 5;
let b = 3;
console.log(a+b);


자료형


List


list-console-log

let a = ['사과','','수박'];
console.log(a);


list-console-log-a-1

let a = ['사과','','수박'];
console.log(a[1]);

* a[1]인데 배를 가져온 이유는 0부터 시작이기 때문, a[0]이 사과!


Dictionary


dictionary

let person = {'name':'bob', 'age': 30, 'height': 180};
console.log(person);


dictionary-name

let person = {'name':'bob', 'age': 30, 'height': 180};
console.log(person['name']);


dictionary-height

let person = {'name':'bob', 'age': 30, 'height': 180};
console.log(person['height']);


dictionary-name-age

let person = {'name':'bob', 'age': 30, 'height': 180};
let name = person['name']
let age = person['age']
console.log(name, age);



3. Javascript IF문


if문

 let age = 15;

if (age < 20) {
    console.log('청소년입니다');
} else {
    console.log('성인입니다');
}



4. Javascript 반복문 forEach


반복문-forEach

let ages = [15, 30 ,28, 7, 40, 13];

console.log(ages[0]);
console.log(ages[1]);
console.log(ages[2]);
console.log(ages[3]);
console.log(ages[4]);
console.log(ages[5]);

이렇게 길어지는 코드를 아래의 반복문으로 간단하게 나타낼 수 있다.


let ages = [15, 30 ,28, 7, 40, 13];

ages.forEach(a => {
    console.log(a);
})



5. Javascript DOM


js-alert

<script>
    function hey() {
        alert('안녕하세요');
    }
</script>

<button onclick="hey()" type="button" class="btn btn-outline-light">영화 기록하기</button>

script에 hey 함수를 만들어주고 영화 기록하기 버튼에 onclick=”hey()” 추가



6. JQuery


JQuery로 조작할 때 id 붙혀주기


text 변경


jquery-text

<script>
    function hey() {
        $('#title').text('쥬라기월드');
    }
</script>

<h1 id="title" class="display-5 fw-bold">킹덤</h1>
<button onclick="hey()" type="button" class="btn btn-outline-light">영화 기록하기</button>

h1에 id를 만들어주고, 버튼에 hey함수 넣으면, 영화 기록하기 버튼 클릭 시 킹덤 글자가 쥬라기월드로 바뀜


empty와 append


example

jquery-exam


empty

jquery-empty

<script>
    function checkResult() {
        $('#q1').empty();
    }
</script>


append

jquery-append

<script>
    function checkResult() {
        let temp_html = `<p>감자</p>`;
        $('#q1').append(temp_html);
    }
</script>


리스트에 있는 것 가져오기

jquery-from-list

<script>
    function checkResult() {
        let fruits = ['사과','','','','수박']
        $('#q1').empty();
        
        let a = fruits[0]
        let temp_html = `<p>${a}</p>`;
        $('#q1').append(temp_html);
    }
</script>