5 분 소요


▶ Firestore란?

  • Firestore란?
    • 파이어스토어(Firestore)는 구글의 클라우드 기반 NoSQL 데이터베이스이다.
  • NoSQL DB란?
    • 자유도가 높고 정형화되어있지 않은 앞으로 바뀔 base가 많을 때 사용한다. (정해진 규칙 x)
    • 따라서 우리는 관계형 DB보다는 비관계형 DB를 주로 사용하게 될 것이다.




▶ Firestore DB 시작하기

▷ 파이어스토어 시작하기

① 빌드에서 Firestore Database 클릭


② DB 만들기 클릭


③ 프로덕션 모드에서 시작하기 클릭


④ Cloud Firestore위치는 Seoul로 설정하고, 사용 설정 클릭


▷ 파이어스토어 규칙 수정하기

① 규칙 클릭


② false → true 변경 후, 게시 클릭


▷ 파이어스토어 세팅 코드 넣기📌

추후 프로젝트 진행시, 이 코드 그냥 복사하면 됨!

① 프로젝트 설정 클릭


② 구성 클릭후 코드 복사


③ VS를 킨 다음, 파이어스토어 세팅 코드 넣기 (DB가 필요한 프로젝트에 넣으면 된다.)
➡️ 저장하지 않았거나 잊어버린 경우 프로젝트 설정 누르면 나와있다.

// Firebase SDK 라이브러리 가져오기
import { initializeApp } from "https://www.gstatic.com/firebasejs/9.22.0/firebase-app.js";
import { getFirestore } from "https://www.gstatic.com/firebasejs/9.22.0/firebase-firestore.js";

// Firebase 구성 정보 설정
const firebaseConfig = {
	본인 설정 내용 채우기
};


// Firebase 인스턴스 초기화
export const app = initializeApp(firebaseConfig);
export const db = getFirestore(app);


④ 그 후, script의 type을 module로 바꿔주자. (바닐라js 사용 시)
⚠️ type을 module로 바꾸면 script가 맨 마지막에 호출되고, onclick 이런거 안되기 때문에, click을 동적으로 만들어줘야한다! (아래에서 다시 설명)

<script type="module">


⚠️ 브라우저 자체의 보안적인 설정으로 인해 외부파일 js가 index.html에 연결되지 않아 html코드 내에서 해당 js코드를 사용해야하는 것이 강제된다고 한다!

따라서 index.html에서 진행해주자.




아래 내용은 [파이어스토어 문서↗️]에서 더 정확히 확인할 수 있다!

▶ addDoc : DB에 데이터 넣기

▷ Firestore DB에 데이터 넣기

  • 버튼에다가 id값을 줘보자
<button id="postingBtn" type="button" class="btn btn-primary">
  기록하기
</button>


  • 데이터를 Firestore DB에 저장하기 위해 아래 코드를 사용하면 된다. 즉, postingBtn에다가 click을 할 시 아래의 메서드가 실행되도록 할 것이다.
$("#postingBtn").click(async function () {
  let doc = {};
  await addDoc(collection(db, "콜렉션이름"), doc);
});


  • 잘 저장되는지 확인하기 위해 let doc에 아래와 같은 데이터를 넣어주자
$("#postingBtn").click(async function () {
  let doc = { name: "sieun", age: "22" };
  await addDoc(collection(db, "albums"), doc);
});


짜잔!🎇 (신기해서 절로 감탄사가 나왔다.. 너무 신기해..)


이제, name과 age가 아닌 이미지, 제목, 내용 날짜의 데이터를 넣어주자

$("#postingBtn").click(async function () {
  let image = $("#image").val();
  let title = $("#title").val();
  let content = $("#content").val();
  let date = $("#date").val();

  let doc = {
    image: image,
    title: title,
    content: content,
    date: date,
  };
  await addDoc(collection(db, "albums"), doc);
});


짜잔!🎇


▷ 데이터 넣고, 화면 새로고침 하기(location, alert)

  • 데이터 넣고, 버튼을 누르면 저장완료 알림이 나오고 화면 새로고침을 해보자! 초간단! 아래 두 줄만 추가하면 된다.
alert("저장 완료!"); // 기록하기 버튼을 눌렀을 때 알림띄우기
window.location.reload(); // 화면 새로고침 하기
$("#postingBtn").click(async function () {
  let image = $("#image").val();
  let title = $("#title").val();
  let content = $("#content").val();
  let date = $("#date").val();

  let doc = {
    image: image,
    title: title,
    content: content,
    date: date,
  };
  await addDoc(collection(db, "albums"), doc);
  alert("저장 완료!");
  window.location.reload();
});

짜잔!🎇


우린 파이어스토어를 사용하기 위해 <script type="module">를 해 주었다! 🥹 하지만 type에 module이 붙는 순간, <button onclick="함수이름()"> 을 수행할 수 없다!! 💡 따라서 직접 button에다가 click을 $("#postingBtn").click 이런식으로 해주면 된다!

  • 먼저, 아래 코드를
<button onclick="openClose()">추억 저장하기</button>
  • onclick이 아닌 id값으로 변경하자.
<button id="saveBtn">추억 저장하기</button>


  • 그 다음, openClose 메서드가 하는 역할을 괄호 안에 추가하자.
$("#saveBtn").click(async function () {
  $("#postingBox").toggle();
});
  • openClose 메서드 (삭제해도됨)
function openClose() {
  $("#postingBox").toggle();
}


➡️ 이렇게 해주면 토글 기능이 정상적으로 작동되는 것을 확인할 수 있다!




▶ getDocs : DB에서 데이터 가져오기

▷ Firestore DB에서 데이터 가져오기

Firestore Database에서 데이터 가져와서 카드를 생성해보자

  • 데이터 읽기 스켈레톤 코드 (데이터 가져오기 : getDocs)
let docs = await getDocs(collection(db, "콜렉션이름"));
docs.forEach((doc) => {
  let row = doc.data();
  console.log(row);
});
  • 짜잔!🎇


  • 데이터를 가져왔으니 카드를 붙여주자 아래의 카드 코드를 가져와서 (가져온 후, makeCard 삭제하기)
function makeCard() {
  let image = $("#image").val();
  let title = $("#title").val();
  let content = $("#content").val();
  let date = $("#date").val();

  let temp_html = `
        <div class="col">
        <div class="card">
          <img
            src="${image}"
            class="card-img-top"
            alt="..."
          />
          <div class="card-body">
            <h5 class="card-title">${title}</h5>
            <p class="card-text">${date}</p>
            <p class="card-text">${content}</p>
          </div>
        </div>
      </div>`;
  $("#card").append(temp_html);
}

여기에 붙여주자!

let docs = await getDocs(collection(db, "albums"));
docs.forEach((doc) => {
  let row = doc.data();
  console.log(row);
  let image = $("#image").val();
  let title = $("#title").val();
  let content = $("#content").val();
  let date = $("#date").val();

  let temp_html = `
        <div class="col">
        <div class="card">
          <img
            src="${image}"
            class="card-img-top"
            alt="..."
          />
          <div class="card-body">
            <h5 class="card-title">${title}</h5>
            <p class="card-text">${date}</p>
            <p class="card-text">${content}</p>
          </div>
        </div>
      </div>`;
  $("#card").append(temp_html);
});


그 후, row의 값이 들어가게 코드를 수정해주자

let image = row["image"];
let title = row["title"];
let content = row["content"];
let date = row["date"];


  • 짜잔!🎇 새로고침하면 아래와 같이 생성된 것을 확인할 수 있다.




▶ 전체 코드

<!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.5.1/jquery.min.js"></script>
    <link
      href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css"
      rel="stylesheet"
      integrity="sha384-T3c6CoIi6uLrA9TneNEoa7RxnatzjcDSCmG1MXxSR1GAsXEV/Dwwykc2MPK8M2HN"
      crossorigin="anonymous"
    />
    <link rel="stylesheet" href="./style.css" />
    <script type="module">
      // Firebase SDK 라이브러리 가져오기
      import { initializeApp } from "https://www.gstatic.com/firebasejs/9.22.0/firebase-app.js";
      import { getFirestore } from "https://www.gstatic.com/firebasejs/9.22.0/firebase-firestore.js";
      import {
        collection,
        addDoc,
      } from "https://www.gstatic.com/firebasejs/9.22.0/firebase-firestore.js";
      import { getDocs } from "https://www.gstatic.com/firebasejs/9.22.0/firebase-firestore.js";

      // Firebase 구성 정보 설정
      // For Firebase JS SDK v7.20.0 and later, measurementId is optional
      const firebaseConfig = {
        apiKey: "AIzaSyDtbTUSAXiXsJv1bvxx4y909zisqSo5uuk",
        authDomain: "happy-882bd.firebaseapp.com",
        projectId: "happy-882bd",
        storageBucket: "happy-882bd.appspot.com",
        messagingSenderId: "915470516981",
        appId: "1:915470516981:web:6249afe8f44cfe8213fbbc",
        measurementId: "G-4C8TY07XXM",
      };

      // Firebase 인스턴스 초기화
      const app = initializeApp(firebaseConfig);
      const db = getFirestore(app);

      $("#postingBtn").click(async function () {
        let image = $("#image").val();
        let title = $("#title").val();
        let content = $("#content").val();
        let date = $("#date").val();

        let doc = {
          image: image,
          title: title,
          content: content,
          date: date,
        };
        await addDoc(collection(db, "albums"), doc);
        alert("저장 완료!");
        window.location.reload();
      });

      $("#saveBtn").click(async function () {
        $("#postingBox").toggle();
      });

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

      let docs = await getDocs(collection(db, "albums"));
      docs.forEach((doc) => {
        let row = doc.data();
        console.log(row);
        let image = row["image"];
        let title = row["title"];
        let content = row["content"];
        let date = row["date"];

        let temp_html = `
        <div class="col">
        <div class="card">
          <img
            src="${image}"
            class="card-img-top"
            alt="..."
          />
          <div class="card-body">
            <h5 class="card-title">${title}</h5>
            <p class="card-text">${date}</p>
            <p class="card-text">${content}</p>
          </div>
        </div>
      </div>`;
        $("#card").append(temp_html);
      });
    </script>
  </head>
  <body>
    <div class="mytitle">
      <h1>나만의 추억 앨범</h1>
      <p>현재 서울의 미세먼지 : <span id="msg"></span></p>
      <button id="saveBtn">추억 저장하기</button>
    </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="form-floating mb-3">
        <input
          type="email"
          class="form-control"
          id="content"
          placeholder="앨범 내용"
        />
        <label for="floatingInput">앨범 내용</label>
      </div>
      <div class="form-floating mb-3">
        <input
          type="email"
          class="form-control"
          id="date"
          placeholder="앨범 날짜"
        />
        <label for="floatingInput">앨범 날짜</label>
      </div>
      <div class="myBtn">
        <button id="postingBtn" type="button" class="btn btn-primary">
          기록하기
        </button>
        <button type="button" class="btn btn-outline-primary">닫기</button>
      </div>
    </div>

    <div class="mycards">
      <div id="card" class="row row-cols-1 row-cols-md-4 g-4">

        </div>
      </div>
    </div>
    <script src="./index.js"></script>
    <script
      src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"
      integrity="sha384-C6RzsynM9kWDrMNeT87bh95OGNyZPhcTNXj1NW7RuBCsyN/o0jlpcV8Qyq46cDfL"
      crossorigin="anonymous"
    ></script>
  </body>
</html>

카테고리:

업데이트:

댓글남기기