# local,session Storage 저장방법

localStorage속성은 사용자 로컬의 Storage (opens new window)객체에 접근하게 해줍니다.localStoragesessionStorage와 비슷합니다. 유일한 차이점은 localStorage에 저장된 데이터는 만료 기간이 없지만, sessionStorage에 저장된 데이터는 세션이 끝나면(브라우저가 종료되면) 지워진다는 것입니다.

# localStorage 문법

myStorage = window.localStorage;

# localStorage 저장 예시

간단한 로컬스토리지에 저장하는 예제입니다.

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>local_ex</title>
  </head>
  <body>
    <input type="button" id="savebtn" value="save" onclick="saveMyStaff()" />
    <input type="button" id="loadbtn" value="load" onclick="load()" />
    <table>
      <tr>
        <td>1box<textarea name="1" id="1" cols="30" rows="10"></textarea></td>
        <td>2box<textarea name="2" id="2" cols="30" rows="10"></textarea></td>
        <td>3box<textarea name="3" id="3" cols="30" rows="10"></textarea></td>
      </tr>
      <tr>
        <td>
          1box_get<textarea name="1" id="4" cols="30" rows="10"></textarea>
        </td>
        <td>
          2box_get<textarea name="2" id="5" cols="30" rows="10"></textarea>
        </td>
        <td>
          3box_get<textarea name="3" id="6" cols="30" rows="10"></textarea>
        </td>
      </tr>
    </table>

    <script>
      let v1 = [];
      let v2 = [];
      let v3 = [];
      function saveMyStaff() {
        document.getElementById("savebtn").value = "저장됨";

        let v_1 = document.getElementById("1").value;
        v1.push(v_1);
        localStorage.setItem("k1", JSON.stringify(v1));
        v_1 = "";

        let v_2 = document.getElementById("2").value;
        v2.push(v_2);
        localStorage.setItem("k2", JSON.stringify(v2));
        let v_3 = document.getElementById("3").value;
        v3.push(v_3);
        localStorage.setItem("k3", JSON.stringify(v3));
      }
      function load() {
        document.getElementById("loadbtn").value = "읽음";
        let storedV1 = JSON.parse(localStorage.getItem("k1"));
        if (storedV1) {
          document.getElementById(4).value = storedV1;
          // storedV1.forEach(function(){
          //     v1 = storedV1;
          // });
          v1 = storedV1;
        }
        let storedV2 = JSON.parse(localStorage.getItem("k2"));
        if (storedV2) {
          document.getElementById(5).value = storedV2;
          v2 = storedV2;
        }
        let storedV3 = JSON.parse(localStorage.getItem("k3"));
        if (storedV3) {
          document.getElementById(6).value = storedV3;
          v3 = storedV3;
        }
      }
      function init() {
        load();
      }
      init();
    </script>
  </body>
</html>

# 데이터 저장 setItem()

  • localStorage에 데이터를 저장하는 방법으로 두가지 방법이 있습니다.
    • 메소드 사용
    • 리터럴
  • 아래 예제는 test라는 이름의 key 값을 정하고 value로 123을 저장하는 예제입니다.
localStorage.setItem("test", "123");
localStorage.test = "123";

# 데이터 불러오기 getItem()

  • localStorage에서 데이터를 불러오는 방법으로 두가지 방법이 있습니다.
    • 메소드 사용
    • 직접 키 입력
localStorage.getItem("test");
localStorage.test;
localStorage.getItem(); //전체 값 받아오기

# 데이터 지우기 removeItem()

  • 특정 key에 저장된 값만 지우기
localStorage.removeItem("test");
  • 전체 값 다 지우기
localStorage.clear();

# sessionStorage 문법

  • sessionStorage은 세션을 기준으로 데이터가 저장, 유지되어 이 객체에 저장된 값은 일시적 수명을 가지게 됩니다. 세션이 종료되거나 브라우저를 닫거나 일정시간 동작을 하지 않으면 값은 삭제됩니다.
  • 보안 및 중요한 데이터 같이 무방비로 노출되는 경우를 피하기 위해 사용합니다.
  • 데이터가 삭제되지 않길 원하면 localStorage를 사용하기 바랍니다.
sessionStorage.setItem("domain", "webisfree.com");
sessionStorage.getItem("domain");
sessionStorage.removeItem("domain");
sessionStorage.clear();
//localStorage와 사용 방법 동일합니다.
#JS
노경환
이 글이 도움이 되셨다면! 깃헙 스타 부탁드립니다 😊😄
최근변경일: 9/23/2024, 2:14:43 AM