localStorage、sessionStorage 和 Cookie 区别及用法

214 阅读1分钟

区别

  • localStorage: localStorage 的生命周期是永久的,关闭页面或浏览器之后 localStorage 中的数据也不会消失。localStorage 除非主动删除数据,否则数据永远不会消失

  • sessionStorage: sessionStorage 的生命周期是仅在当前会话下有效。sessionStorage 引入了一个“浏览器窗口”的概念,sessionStorage 是在同源的窗口中始终存在的数据。只要这个浏览器窗口没有关闭,即使刷新页面或者进入同源另一个页面,数据依然存在。但是 sessionStorage 在关闭了浏览器窗口后就会被销毁。同时独立的打开同一个窗口同一个页面,sessionStorage 也是不一样的

  • cookie: cookie生命期为只在设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭。 存放数据大小为4K左右, 有个数限制(各浏览器不同),一般不能超过20个。缺点是不能储存大数据且不易读取

用法

localstorage 和 sessionstorage

  1. 首先要判断浏览器是否支持 localStorage / sessionStorage
    比如判断 localStorage
    if (window.localStorage) {
        alert('浏览支持 localStorage');
    } else {
        alert('浏览暂不支持 localStorage');
    }
  1. localStorage 和 sessionStorage 都具有相同的操作方法,例如 setItem()getItem() 和 removeItem() 等

储存数据

    sessionStorage.setItem('key', 'value');
    localStorage.setItem('key', 'value');

取出数据

    sessionStorage.getItem('key');
    localStorage.getItem('key');

修改数据

    sessionStorage.setItem('key', 'newVal');
    localStorage.setItem('key', 'newVal');

删除数据

    sessionStorage.removeItem('key');
    localStorage.removeItem('key');

清除数据

    sessionStorage.clear();
    localStorage.clear();

cookie

储存数据

window.document.cookie = 'key=val';

取出数据

document.cookie

example:

// 设置 Cookie
setCookie(key, val, days) {
    let date = new Date(); // 获取时间
    date.setTime(date.getTime() + 24 * 60 * 60 * 1000 * days);
    // 字符串拼接 Cookie
    window.document.cookie = `${key}=${val};path=/;expires=${date.toGMTString()};`;
}
// 获取 Cookie
getCookie() {
    let cookie = document.cookie.split(';');
}
// 清除Cookie
clearCookie() {
    this.setCookie('', '', -1);
}