[Vue.js] localStorage와 sessionStorage로 웹 스토리지 활용하기

2023. 10. 23. 21:29· Vue.js
목차
  1. [들어가기 전에]
  2. [localStorage]
  3. 📌 저장하기
  4. 📌 가져오기
  5. 📌 삭제하기
  6. [sessionStorage]
  7. 📌 저장하기
  8. 📌 가져오기
  9. 📌 삭제하기
  10. [객체 저장]

[들어가기 전에]

개발을 하다 보면 웹 스토리지에 있는 값을 가져오고 싶을 때가 있습니다.

웹 페이지 팝업 창에서 '오늘 하루 보지 않기' 같은 기능이 그 예인데요. 사용자가 해당 기능을 사용할 때 체크했는지 여부를 저장해야 합니다. 물론 웹 페이지가 닫히고 나서도 계속 유지해야 하지요.

 

이때 유용한 게 웹 스토리지입니다.

웹 스토리지는 데이터를 영구적 혹은 세션이 유지되는 동안 저장하고 가져올 수 있습니다.

https://developer.mozilla.org/en-US/docs/Web/API/Web_Storage_API

 

Web Storage API - Web APIs | MDN

The Web Storage API provides mechanisms by which browsers can store key/value pairs, in a much more intuitive fashion than using cookies.

developer.mozilla.org

[localStorage]

localStorage는 말 그대로, local에 있는 저장소를 의미합니다.

웹 브라우저가 닫히거나 컴퓨터가 재시작되더라도 데이터는 계속 유지됩니다. 만료 기간이 없기 때문에 직접 지우지 않는 한 영영 살아있는 것이죠.

 

사용 방법은 다음과 같습니다.

📌 저장하기

첫 번째 전달인자에는 key, 두 번째 전달인자에는 value를 넣으면 됩니다.

localStorage.setItem('name', 'silverCastle');

📌 가져오기

전달인자에 가져올 key를 넣으면 됩니다.

let localValue = localStorage.getItem('name');

📌 삭제하기

전달인자에 삭제할 key를 넣으면 됩니다.

localStorage.removeItem('name');

localStorage에 저장된 모든 값들을 삭제하고 싶다면?

localStorage.clear();

[sessionStorage]

sessionStorage는 말 그대로, session에 있는 저장소를 의미합니다.

여기서 session은 흔히 서버에서 관리하는 session과는 다른 개념인데 사용자가 웹 브라우저를 열어 탭을 사용하고 닫을 때까지의 기간을 의미합니다. 즉, 탭을 닫으면 스스로 없어지게 되는 거죠.

 

사용 방법은 localStorage와 동일한데 sessionStorage로 바꿔주기만 하면 됩니다..!

📌 저장하기

sessionStorage.setItem('name', 'silverCastle');

📌 가져오기

let sessionValue = sessionStorage.getItem('name');

📌 삭제하기

sessionStorage.removeItem('name');

sessionStorage에 저장된 모든 값들을 삭제하고 싶다면?

sessionStorage.clear();

[객체 저장]

localStorage와 sessionStorage는 기본적으로 객체 저장을 지원하지 않습니다.

하지만, 객체를 문자열로 변환한다면 저장할 수 있는데요. JSON.stringify()을 사용하면 됩니다.

그리고 JSON.parse()을 사용해서 저장된 문자열을 객체로 변환하여 가져올 수 있습니다.

let obj = {
  name: 'silverCastle',
  age: 26,
};

// 객체 저장하기
localStorage.setItem('myObj', JSON.stringify(obj));

// 객체 가져오기
let retrievedObj = JSON.parse(localStorage.getItem('myObj'));

// 객체 삭제하기
localStorage.removeItem('myObj');
저작자표시 (새창열림)

'Vue.js' 카테고리의 다른 글

[Vue.js] User-Agent를 활용하여 iOS, Android 구분하기  (0) 2023.11.02
[Vue.js] provide와 inject 사용 방법  (0) 2023.10.20
[Vue.js] mitt 라이브러리로 이벤트 핸들링하기  (0) 2023.10.13
[Vue.js] .env 파일로 환경 변수 관리하기  (0) 2023.10.04
[Vue.js] v-slot으로 컴포넌트 효율적으로 사용하기  (0) 2023.09.25
  1. [들어가기 전에]
  2. [localStorage]
  3. 📌 저장하기
  4. 📌 가져오기
  5. 📌 삭제하기
  6. [sessionStorage]
  7. 📌 저장하기
  8. 📌 가져오기
  9. 📌 삭제하기
  10. [객체 저장]
'Vue.js' 카테고리의 다른 글
  • [Vue.js] User-Agent를 활용하여 iOS, Android 구분하기
  • [Vue.js] provide와 inject 사용 방법
  • [Vue.js] mitt 라이브러리로 이벤트 핸들링하기
  • [Vue.js] .env 파일로 환경 변수 관리하기
eunex
eunex
eunex
성장하는 자기개발자
eunex
전체
오늘
어제
  • 분류 전체보기
    • jQuery
    • JavaScript
    • Vue.js
    • React
    • iOS
    • 자격증
    • Algorithm
    • Python
    • 회고
    • CS
    • 정보처리기사 실기
    • JSP
    • 은행실무기초

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • ref
  • 자격증
  • 상반기
  • 개발자
  • 회고
  • vue
  • Reactive
  • watchEffect
  • ADsP
  • computed
  • proxy
  • watch
  • SQLD

최근 댓글

최근 글

hELLO · Designed By 정상우.v4.2.0
eunex
[Vue.js] localStorage와 sessionStorage로 웹 스토리지 활용하기

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.