TIL

[본캠프] 1주차 월요일 TIL

news0516 2024. 10. 28. 21:13

오늘 배운 내용
웹개발 4, 5주차 강의
Firebase
- 구글이  개발한 플랫폼
- 구글이 제공한 벡엔드를 사용해 프론트엔드에 집중하여 개발할 수 있음
- 서버 인프라에 대한 직접적인 컨트롤이 어렵다

- 구글 서비스에 의존하게 되어 외부 다른 서비스나 기능을 활용하기 어렵다.

데이터베이스(DB)란?
데이터를 저장하고 여러사람들이 관라히는 데이터의 모음

Firestore
- 구글의 클라우드 기반 NoSQL 데이터베이스
Firestore 세팅 코드를 추가하여 데이터베이스에 데이터를 저장할 수 있다.

getDoc을 사용하여 데이터베이스에 저장된 정보를 꺼내올 수 있다.

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

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>내플릭스</title>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
    <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=Black+And+White+Picture&display=swap');

        * {
            font-family: "Black And White Picture", system-ui;
            font-style: normal;
            font-weight: 400;
        }

        .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;
            padding: 20px;
            border-radius: 5px;
        }

        .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>
    <script type="module">
        // Firebase SDK 라이브러리 가져오기
       

        // For Firebase JS SDK v7.20.0 and later, measurementId is optional
        
        // Firebase 인스턴스 초기화
        

        $("#hostingbtn").click(async function () {
            let image = $('#image').val();
            let title = $('#title').val();
            let star = $('#star').val();
            let comment = $('#comment').val();
            let doc = {
                'image': image,
                'title': title,
                'star': star,
                'comment': comment
            };
            await addDoc(collection(db, "movies"), doc);
            alert('저장 완료')
            window.location.reload()

        })

        $("#savebtn").click(async function () {
            $('#postingbox').toggle();
        })

        let url = "http://spartacodingclub.shop/sparta_api/weather/seoul";
        fetch(url).then(res => res.json()).then(data => {
            let temp = data['temp']
            if (temp > 20) {
                $('#msg_t').text('더워요')
            } else {
                $('#msg_t').text('추워요')
            }
        })

        let docs = await getDocs(collection(db, "movies"));
        docs.forEach((doc) => {
            let row = doc.data();

            let image = row['image']
            let title = row['title']
            let star = row['star']
            let comment = row['comment']

            let temp_html = `<div class="col">
                <div class="card h-100">
                    <img src="${image}"
                        class="card-img-top" alt="...">
                    <div class="card-body">
                        <h5 class="card-title">${title}</h5>
                        <p class="card-text">${star}</p>
                        <p class="card-text">${comment}</p>
                    </div>
                </div>
            </div>`;

            $('#card').append(temp_html);
        });
    </script>
</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">myflix</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>
                    <li><a href="#" class="nav-link px-2 text-white">현재 기온 : <span id="msg_t"></span></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 id="savebtn" class="btn btn-outline-light" type="button">영화 기록하기</button>
                <button class="btn btn-outline-light" type="button">상세정보</button>
            </div>
        </div>
    </div>
    <div class="mypostingbox" id="postingbox">
        <div class="form-floating mb-3">
            <input type="email" class="form-control" id="image" placeholder="앨범 이미지">
            <label for="floatingInput">영화 이미지 주소</label>
        </div>
        <div class="form-floating mb-3">
            <input type="email" class="form-control" id="title" 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="star">
                <option selected>별점 선택</option>
                <option value="⭐">⭐</option>
                <option value="⭐⭐">⭐⭐</option>
                <option value="⭐⭐⭐">⭐⭐⭐</option>
                <option value="⭐⭐⭐⭐">⭐⭐⭐⭐</option>
                <option value="⭐⭐⭐⭐⭐">⭐⭐⭐⭐⭐</option>
            </select>
        </div>
        <div class="form-floating mb-3">
            <input type="email" class="form-control" id="comment" placeholder="추천 이유">
            <label for="floatingInput">추천 이유</label>
        </div>
        <button id="hostingbtn" class="btn btn-danger" type="button">기록하기</button>
    </div>
    <div class="mycards">
        <div id="card" class="row row-cols-1 row-cols-md-4 g-4">
        </div>
    </div>

</body>

</html>

 
<script type = "module"> 사용 시 onClick 대신 id를 부여하여 작성한다,
Firebase를 사용한다면 클릭을 동적으로 따로 만들어준다.
기록하기 버튼 클릭 시 DB저장 후 꺼내져 새로운 카드로 추가된다.

이후 작성한 페이지 배포, Github 시작, 파이썬 맛보기를 진행하였다.

5조 S.A 작성
팀이름 V
자기소개 후 Ground Rules, Goals, 회의시간 설정
팀원의 간략한 역할 분배를 진행후 튜터님께 피드백을 받아
- 코드 공유 위한 깃허브 리포지토리 생성

- 중간회의시간 대신 업무 분담

- 헤더에 대한 내용 추가, 페이지 별로 같은 내용 사용할 수 도 있음

- 게시판 기능을 댓글을 남길 수 있는 방명록으로 변경

해당 사항들을 수정하였고 그에 맞는 와이어프레임 또한 잓성하였다.

현재 왕초보 웹개발 강의를 완강하지 못한 인원은 빠른 시간내 완강을 목표로 진행하였고, 완강한 인원은 가장 쉬운 부분인 팀 소개 페이지를 작성하였다.

내일부터 본격적인 구현에 들어가게 될텐데 오늘만해도 많은 부족함을 느껴 튜터님에게 도움 받는 과정이 많이 필요할 것 같다.

금일 강의 모두 듣기를 완료하여 내일 아침 역할 분담 후 내 역할에 집중할 계획

'TIL' 카테고리의 다른 글

1주차 수요일 TIL  (0) 2024.10.30
[본캠프] 2주차 화요일 TIL  (0) 2024.10.29
4주차 수요일  (0) 2024.10.23
4주차 월요일  (1) 2024.10.21
3주차 금요일  (0) 2024.10.18