javaScript中的Cookie和web Storage(LocalStorage-SessionStorage)详解

javaScript中的Cookie和web Storage(LocalStorage-SessionStorage)

一、Cookie

cookie称之为会话跟踪技术,顾名思义,就是在一次会话中跟踪记录一些状态。首先,所谓的”会话“指的就是从浏览器打开一个网站到访问它的其他网页直到浏览器关闭的这个过程。
cookie就可以在一次会话从开始到结束的整个过程,全程跟踪记录客户端的状态(例如:是否登录、购物车信息、是否已下载、是否 已点赞、视频播放进度等等)。

Cookie的特点

  1. 只能存储文本
  2. 单条存储有大小限制4KB左右
  3. 数量限制:一般浏览器,限制大概在50条左右
  4. 读取有域名限制:不可跨域读取,只能由来自 写入cookie的 同一域名 的网页可进行读取。
  5. 时效限制:每个cookie都有时效,默认的有效期是,会话级别:就是当浏览器关闭,那么cookie立即销毁,但是我们也可以在存储的时候手动设置cookie的过期时间
  6. 路径限制:存cookie时候可以指定路径,只允许子路径读取外层cookie,外层不能读取内层。一般cookie都存在项目的根目录,这样就可以避免这种问题。

cookie的使用

cookie的使用方式很简单😄,系统提供的只有一个属性 document.cookie,无论是存还是取或者其他操作都是通过这一个属性来完成

  • 存:
document.cookie="name=xiaoming";  // 存一条name为xiaoming的cookie;
document.cookie = "age=30"; // document.cookie反复赋值不是覆盖,而是存多条cookie
document.cookie = 'name=zhangsan'; //相同name为修改(覆盖)

在这里插入图片描述

如果想要存一条中文的cookie,比如:uname=张三,在部分低版本浏览器就会遇到一些位置错误,这时就可以使用 encodeURIComponent 编码对中文进行编码

var name="张三";
document.cookie="name="+encodeURIComponent(name);
在这里插入图片描述

取得时候可以通过decodeURIComponent 方法进行解码

  • 取:
    这里直接console.log(document.cookie)就行;
 console.log(document.cookie);
在这里插入图片描述

这里出现这种编码是因为刚才存的时候用encodeURIComponent进行了编码


在这里插入图片描述

当我们不想要这条cookie的时候我们可以点这里删除或者清除所有
当然我们也可以用代码来删除,下面会封装一个删除的方法的,当然也会封装存和取的方法。

  • cookie的时效性


    在这里插入图片描述
    • 从上面图可以看到存过的cookie,其中有Expires/max-Age选项,这一项指的就是cookie的有效期,我们可以看到是session,代表会话期,也就是默认的会话结束cookie失效,这时我们重启浏览器就看不到这条cookie了。
    • 除了默认的会话过期我们还可以手动设置cookie的过期时间,比如:7天后过期
        var date = new Date();
        date.setDate(date.getDate() + 7);
        document.cookie = `name=lisi;expires=${date.toUTCString()}`;
    
    在这里插入图片描述

    toUTCString()方法转成了标准时区,所以比北京时间快8个小时,这时我们关闭浏览器再次打开,仍然可以看到这条cookie

  • cookie的存储路径


    在这里插入图片描述

    可以看见是指定路径的但是在其他路径是拿不到的,所以我们可以把路径指向根目录这样下面的子目录都可以访问这条cookie了

document.cookie = "name=lisi;path=/";

所以下面我们就可以封装cookie方法啦

封装一个存cookie的方法

/** 存一条cookie
 * @param {string} key 要存的cookie的名称
 * @param {string} value 要存的cookie的值
 * @param {object} [options] 可选参数,过期时间和目录,如:{ path: '/', expires: 7 }存根目录7天过期的cookie
 */
function setCookie (key, value, options) {
    var str = `${key}=${encodeURIComponent(value)}`
    // 先判断options是否传进来了
    //encodeURIComponent是进行编码
    if (options) {
        // 如果传进来了再判断有哪个属性
        if (options.path) {
            // 路径拼接进去
            str += `;path=${options.path}`;
        }
        if (options.expires) {
            var date = new Date();
            // 日期设置为过期时间
            date.setDate(date.getDate() + options.expires);
            str += `;expires=${date.toUTCString()}`;
        }
    }
    document.cookie = str;
}

//使用setCookie ("name", '张三', {path:"/",expires:5});

封装一个取cookie的方法

取cookie同样使用document.cookie这个属性;但是我们可以看到是带有name属性和=的,我们想要通过name属性拿到属性值怎么办?

/** 获取某一条cookie
 * @param {string} key 要获取的cookie的名称
 * @retrun {string} 当前这条cookie的值
 */
getCookie (key) {
    var str = document.cookie;
    var arr = str.split('; ');
    //多条cookie之间以"; ""; 隔开的
    var obj = new Object();
    arr.forEach(item => {
        var subArr = item.split('=');
        obj[subArr[0]] = decodeURIComponent(subArr[1]);
        //decodeURIComponent是进行解码
    })
    return obj[key];
}
//使用getCookie (key);

封装一个删除cookie的方法

/** 删一条cookie
 * @param {string} key 要删的cookie的名称
 * @param {path} [path] 可选参数,要删的cookie的所在的路径,如果就是当前路径这个参数可以不传
 */
function removeCookie (key, path) {
    var date = new Date();
    date.setDate(date.getDate() - 1); // 过期时间设置为昨天
    var str = `${key}='';expires=${date.toUTCString()}`;
    if (path) {
        str += `;path=${path}`;   
    }
    document.cookie = str;
}

也可以用存cookie的方法把expires为-1即可

setCookie ("name", '', {path:"/",expires:-1});

修改cookie

从新存一个相同name把之前的覆盖掉就是修改cookie了

封装一个 增删改查 一体的cookie

// 通过判断有没有传第二个参数value来决定是存还是取
// 这个方法也可以用于删cookie,比如:cookie('username', '', { expires: -1, path: '/' })
function cookie (key, value, options) {
    if (value) {
        var str = `${key}=${encodeURIComponent(value)}`
        if (options) {
            if (options.path) {
                str += `;path=${options.path}`;
            }
            if (options.expires) {
                var date = new Date();
                date.setDate(date.getDate() + options.expires);
                str += `;expires=${date.toUTCString()}`;
            }
        }
        document.cookie = str;
    } else {
        var str = document.cookie;
        var arr = str.split('; ');
        var obj = new Object();
        arr.forEach(item => {
            var subArr = item.split('=');
            obj[subArr[0]] = decodeURIComponent(subArr[1]);
        })
        return obj[key];
    }
}

二、web Storage(LocalStorage-SessionStorage)

  • h5新增的
  • 大小可以存5M左右
  • 过期时间不可配置的
    • localStorage 永不过期,只要不用代码手动删除就一直在
    • sessionStorage 会话期有效,关闭浏览器就清除
  • 不存在路径问题,无论在那存当前网站的任意路径都可以使用
  • js本身提供了存取的api,两种api是一样的

localStorage存

localStorage.setItem('name', '李四');

localStorage取

value = localStorage.getItem('name');
console.log(value);

localStorage删

localStorage.removeItem('name'); //删除一条
localStorage.clear(); //删除所有
  • localStorage一般用于本地存储一些比较大的数据
  • sessionStorage的用法和localStorage一摸一样,区别只是在于有效期

sessionStorage存

sessionStorage.setItem('name', '李四');

sessionStorage取

value = sessionStorage.getItem('name');
console.log(value);

sessionStorage删

sessionStorage.removeItem('name'); //删除一条
sessionStorage.clear(); //删除所有

总结Cookie和web Storage异同点及优劣势

Cookie和web Storage的相同点

  • 都可以用于存储用户数据
  • 存储数据的格式都是字符串形式
  • 存储的数据都有大小限制

Cookie和web Storage的不同点

  • 生命周期不同。sessionStorage 的生命周期是一个会话,localStorage的生命周期是永久,cookie 的生命周期可以自定义,cookie 可以设置过期时间,数据在过期时间之前可以访问。
  • 存储大小限制不同。大部分现代浏览器 Storage 的存储限制大小为 5M,cookie 的存储大小限制 为 4K。
  • 浏览器支持不同,API 调用方式不同。

Cookie和web Storage的优劣势

  • 真实项目中其实前端很少操作cookie,一般由后端来种cookie一般cookie存后端给的令牌,带着这个令牌请求后端数据
  • web Storage一般用于本地存储一些比较大的数据,优点在于存储空间大
  • cookie每次都随请求数据发送到服务器端,Web Storage不会和请求数据一同发送到服务器端,占用带宽更少
  • cookie支持所有浏览器,而Web Storage只有现在的浏览器才支持,如果需要兼容老版本浏览器就不能使用Web Storage

今天分享就到这里啦,喜欢就关注一波呗~~~以上内容全部由自己整理,就有发现问题欢迎评论一起讨论学习-_-

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352