LocalStorage in Browser

1 분 소요


RECOMMEND POSTS BEFORE THIS

1. LocalStorage

localStorage 객체는 웹 스토리지(web storage) 중 하나입니다. localStorage 객체를 통해 브라우저 내에 키-값(key-value) 데이터 쌍을 저장할 수 있습니다.

2. Characteristics of LocalStorage

localStorage 객체는 다음과 같은 특징을 가집니다.

  • localStorage에 저장한 데이터는 브라우저에 의해 자동으로 서버에게 요청되지 않습니다.
  • localStorage에 저장한 데이터는 브라우저를 다시 실행해도 사라지지 않습니다.
  • 대부분의 브라우저들은 도메인 별로 최소 2MB, 최대 5BM 정도의 데이터를 저장할 수 있습니다.
  • 데이터를 문자열(string) 형식으로 저장합니다.
  • 브라우저 탭(tab) 간의 데이터를 공유할 수 있습니다.
  • 서버는 HTTP 응답 헤더를 통해 localStorage에 저장된 데이터를 제어할 수 없습니다.
  • localStorage 데이터는 동일 출처(origin)에 따라 관리됩니다.
    • 도메인, 프로토콜, 포트를 통해 동일 출처 여부를 결정합니다.
    • 서브 도메인, 프로토콜, 포트 등이 다른 경우 localStorage에 저장된 데이터에 접근할 수 없습니다.

3. Main Methods of LocalStorage

다음과 같은 기능을 가집니다.

  • setItem(key, value) – 키-값 쌍을 보관합니다.
  • getItem(key) – 키에 해당하는 값을 받아옵니다.
  • removeItem(key) – 키와 해당 값을 삭제합니다.
  • clear() – 모든 것을 삭제합니다.
  • key(index) – 인덱스(index)에 해당하는 키를 받아옵니다.
  • length – 저장된 항목의 개수를 얻습니다.

4. Practices

localStorage 객체의 특징을 이해하기 위해 몇 가지 실습을 진행하였습니다. 브라우저 개발자 도구의 콘솔(console) 창에서 테스트가 가능합니다.

문자열 저장
  • localStorage 객체는 데이터를 문자열 형식으로 저장합니다.
  • 숫자, 객체는 문자열로 변경되어 저장되므로 주의해야합니다.
  • 다음과 데이터를 저장하고 다시 읽어봅니다.
    • 일반적인 문자열
    • 일반 객체
    • JSON 객체
localStorage.setItem("Hello", "World")
localStorage.getItem("Hello") // "World"

localStorage.setItem("Hello", {a: 'Hello', b: 'World'})
localStorage.getItem("Hello") // "[object Object]"

localStorage.setItem("Hello", JSON.stringify({a: 'Hello', b: 'World'}))
localStorage.getItem("Hello") // "{\"a\":\"Hello\",\"b\":\"World\"}"
JSON.parse(localStorage.getItem("Hello")) // Object { a: "Hello", b: "World" }
동일 출처(origin) 및 신규 브라우저 탭 데이터 공유 여부
  • 출처가 다른 경우 localStorage에 저장된 데이터를 볼 수 있는지 확인합니다.
    • https://junhyunny.github.io/ 경로에 데이터를 저장합니다.
    • 새로운 탭을 열고 https://github.com 사이트로 접속하여 저장된 데이터를 확인합니다.
    • 새로운 탭을 열고 https://junhyunny.github.io/ 사이트로 접속하여 저장된 데이터를 확인합니다.
  • 동일 출처를 가진 새로운 브라우저 탭에서 데이터를 찾을 수 있습니다.
    • https://github.com 사이트에서는 데이터를 찾을 수 없습니다.
    • https://junhyunny.github.io/ 사이트에서는 데이터를 찾을 수 있습니다.

브라우저를 다시 열었을 때 데이터 존재 여부
  • 브라우저를 다시 열었을 때 이전에 저장한 데이터가 남아있는지 확인합니다.
    • 이전에 저장한 데이터가 존재합니다.

RECOMMEND NEXT POSTS

REFERENCE

카테고리:

업데이트:

댓글남기기