오늘 배운 내용
웹개발 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 |