Vue(Vue2+Vue3)——38.浏览器存储(webStorage)

简介: Vue(Vue2+Vue3)——38.浏览器存储(webStorage)

38 浏览器存储(webStorage)


存储内容不是Vue团队打造的,原本的js中就有,所以可以不适用脚手架编译,可以写在HTML中

webStorage又分为localStorage和sessionStorage,浏览器端通过 Window.sessionStorage 和 Window.localStorage 属性来实现本地存储机制。

存储内容大小一般支持5MB左右(不同浏览器可能还不一样),它的键值对都是字符串

下面通过一个常见的应用案例来解释说明


38.1 浏览器本地存储应用


浏览器本地存储应用就是在本地浏览器中缓存些东西到硬盘中

下面以唯品会为例子演示,搜索框输入皮鞋,回车搜索

关闭页面,再次打开网页,发现皮鞋存在了搜索历史中

这里我是没有登录的,所以不可能是存入到数据库,浏览器本地存储是存储到硬盘的

通过控制的Application的LocalStorage中可以看到

可以看到是以键值对的形式存储的

如果我们新增一个,可以看到搜索历史中又多了一个

点击❌则会清空

这就是浏览器本地存储应用,我们也是可以通过代码实现类似的功能,下面进行演示


38.2 localStorage(本地存储)


localStorage的最大特点就是就算把浏览器关闭掉也不会消息。如果想把清除它,可以清除缓存

可以通过JS控制ocalStorage的crud,编写几个按钮,分别对localStorage里面的数据进行crud


新增字符串


使用 window.localStorage.setItem('xxx','xxx')方法即可新增,是键值对的形式,window可写可不写

注意:键和值必须都是字符串,如果不是字符串,会默认调用toString()方法


新增对象


如果新增的不是一个字符串,而是一个对象呢,如果直接新增的话,肯定会被toString

所以要使用JSON.stringify格式化处理下

这样新增的时候就可以新增一个字符串和一个对象了


读取字符串


既然设置(新增)使用的是setItem,那么读取肯定就是getItem了,根据key读取,有返回值


读取对象


上面读取对象的格式不是我们想要的,我们需要解析一下

如果读取字符串的是key不存在,那么则显示null

如果读取对象的key不存在,那么也显示null


删除


使用的api是removeItem,根据key删除localStorage中的数据


清空


和删除类似,删除是根据key删除单个,但是清空会删除全部的,这个api是clear

代码如下

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>localStorage</title>
</head>
<body>
    <h2>localStorage</h2>
    <button onclick="saveData()">点我保存一个数据</button>
    <button onclick="readData()">点我读取一个数据</button>
    <button onclick="deleteData()">点我删除一个数据</button>
    <button onclick="clearData()">清空全部的数据</button>
</body>
<script>
    function saveData(){
        // 向localStorage中存储数据,是键值对的形式 键和值必须都是字符串
        let p={'name':'张三',age:18}
        // 新增对象
        localStorage.setItem('person',JSON.stringify(p))
        // 新增字符串
        localStorage.setItem('msg','hello')
    } 
    function readData(){
        // 根据key读取localStorage中的数据
        // 读取字符串
        console.log(localStorage.getItem('msg'))
        // 读取对象,先解析
        console.log(JSON.parse(localStorage.getItem('person')))
    }
    function deleteData(){
        //  根据key删除localStorage中的数据
        localStorage.removeItem('msg')
    }
    function clearData(){   
        // 清空全部的数据
        localStorage.clear()   
    }
</script>
</html>

到了这里localStorage的应用和查看方式以及简单crud就说完了,localStorage的最大特点就是就算把浏览器关闭掉也不会消息,下面介绍sessionStorage


38.3 sessionStorage(会话存储)


localStorage有一个弟弟叫sessionStorage,它的特点就是浏览器已关闭,数据就没了

localStorage的所有API都可以适用于sessionStorage


既然localStorage的所有API都可以适用于sessionStorage,那么就可以复制刚才localStorage的代码进行简单修改

注意:使用sessionStorage的API要把localStorage进行替换

功能都是一样的,就不贴图了,而且关闭浏览器重新打开后,数据会消失


38.5 总结


相关API:

   1. xxxxxStorage.setItem('key', 'value'); 该方法接受一个键和值作为参数,会把键值对添加到存储中,如果键名存在,则更新其对应的值。

   2.xxxxxStorage.getItem('person'); 该方法接受一个键名作为参数,返回键名对应的值。

   3. xxxxxStorage.removeItem('key');该方法接受一个键名作为参数,并把该键名从存储中删除。

   4.  xxxxxStorage.clear()该方法会清空存储中的所有数据。

4. 备注:

   1. SessionStorage存储的内容会随着浏览器窗口关闭而消失。

   2. LocalStorage存储的内容,需要手动清除才会消失。

   3. xxxxxStorage.getItem(xxx)如果xxx对应的value获取不到,那么getItem的返回值是null。

   4. JSON.parse(null)的结果依然是null。

相关文章
|
11月前
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
805 14
|
5月前
|
JavaScript 前端开发 算法
Vue 3 和 Vue 2 的区别及优点
Vue 3 和 Vue 2 的区别及优点
|
4月前
|
JavaScript 前端开发 API
Vue 2 与 Vue 3 的区别:深度对比与迁移指南
Vue.js 是一个用于构建用户界面的渐进式 JavaScript 框架,在过去的几年里,Vue 2 一直是前端开发中的重要工具。而 Vue 3 作为其升级版本,带来了许多显著的改进和新特性。在本文中,我们将深入比较 Vue 2 和 Vue 3 的主要区别,帮助开发者更好地理解这两个版本之间的变化,并提供迁移建议。 1. Vue 3 的新特性概述 Vue 3 引入了许多新特性,使得开发体验更加流畅、灵活。以下是 Vue 3 的一些关键改进: 1.1 Composition API Composition API 是 Vue 3 的核心新特性之一。它改变了 Vue 组件的代码结构,使得逻辑组
1303 0
|
11月前
|
缓存 JavaScript 前端开发
Vue3与Vue2生命周期对比:新特性解析与差异探讨
Vue3与Vue2生命周期对比:新特性解析与差异探讨
499 3
|
6月前
|
JavaScript 前端开发 UED
vue2和vue3的响应式原理有何不同?
大家好,我是V哥。本文详细对比了Vue 2与Vue 3的响应式原理:Vue 2基于`Object.defineProperty()`,适合小型项目但存在性能瓶颈;Vue 3采用`Proxy`,大幅优化初始化、更新性能及内存占用,更高效稳定。此外,我建议前端开发者关注鸿蒙趋势,2025年将是国产化替代关键期,推荐《鸿蒙 HarmonyOS 开发之路》卷1助你入行。老项目用Vue 2?不妨升级到Vue 3,提升用户体验!关注V哥爱编程,全栈开发轻松上手。
372 2
|
10月前
|
JavaScript 前端开发 API
Vue 3 中 v-model 与 Vue 2 中 v-model 的区别是什么?
总的来说,Vue 3 中的 `v-model` 在灵活性、与组合式 API 的结合、对自定义组件的支持等方面都有了明显的提升和改进,使其更适应现代前端开发的需求和趋势。但需要注意的是,在迁移过程中可能需要对一些代码进行调整和适配。
412 60
|
6月前
|
JavaScript 前端开发 API
管理数据必备;侦听器watch用法详解,vue2与vue3中watch的变化与差异
一篇文章同时搞定Vue2和Vue3的侦听器,是不是很棒?不要忘了Vue3中多了一个可选项watchEffect噢。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
10月前
|
JavaScript 前端开发 API
从Vue 2到Vue 3的演进
从Vue 2到Vue 3的演进
178 17
|
10月前
|
JavaScript 前端开发 API
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
256 17
|
11月前
|
存储 缓存 JSON
vue2知识点:浏览器本地缓存
vue2知识点:浏览器本地缓存
114 2