Vue 浏览器本地存储

一、webStorage

1.存储内容大小一般支持5MB左右(不同浏览器可能不一样)。

2.浏览器通过Window.sessionStorageWindow.localStorage属性来实现本地存储机制。

3.相关API:

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

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

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

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

4.备注:

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

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

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

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

html 复制代码
/* localStorage */
<body>
    <h1>localStorage</h1>
    <button onclick="saveData()">点我存储一个数据</button>
    <button onclick="readData()">点我读取一个数据</button>
    <button onclick="deleteData()">点我删除一个数据</button>
    <button onclick="deleteAllData()">点我清除一个数据</button>

    <script>
        let obj ={name:'张三',age:18}
        function saveData(){
            console.log(1)
            localStorage.setItem('msg','你好')
            localStorage.setItem('msg2','localStorage')
            localStorage.setItem('person',JSON.stringify(obj))
        }
        function readData(){
            console.log(localStorage.getItem('msg'))
            
            console.log(localStorage.getItem('msg2'))
            
            let e = localStorage.getItem('person')
            console.log(JSON.parse(e))
            
        }
        function deleteData(){
            localStorage.removeItem('msg')
        }
        function deleteAllData(){
            localStorage.clear()
        }
    </script>
</body>

/* sessionStorage */
<body>
    <h1>sessionStorage</h1>
    <button onclick="saveData()">点我存储一个数据</button>
    <button onclick="readData()">点我读取一个数据</button>
    <button onclick="deleteData()">点我删除一个数据</button>
    <button onclick="deleteAllData()">点我清除一个数据</button>

    <script>
        let obj ={name:'张三',age:18}
        function saveData(){
            console.log(1)
            sessionStorage.setItem('msg','你好')
            sessionStorage.setItem('msg2','localStorage')
            sessionStorage.setItem('person',JSON.stringify(obj))
        }
        function readData(){
            console.log(sessionStorage.getItem('msg'))
            
            console.log(sessionStorage.getItem('msg2'))
            
            let e = sessionStorage.getItem('person')
            console.log(JSON.parse(e))
            
        }
        function deleteData(){
            sessionStorage.removeItem('msg')
        }
        function deleteAllData(){
            sessionStorage.clear()
        }
    </script>
</body>

二、TodoList_本地存储

利用localStorage.setItem 和 localStorage.getItem的存储和读取机制来动态存储TodoList的数据。通过watch监视todoList数据的变动,每当数组修改,就会用新的数组覆盖掉浏览器本地存储中的旧数组。

....................

data() {

return {

todoList: JSON.parse(localStorage.getItem('todoList')) || []

}

},

....................

watch:{

todoList:{

deep:true,

handler(value){

localStorage.setItem('todoList',JSON.stringify(value))

}

}

}

相关推荐
卤蛋fg62 小时前
vxe-table 如何实现分组列头折叠列功能
vue.js
小怪点点2 小时前
vue3使用
前端·vue.js
进击的尘埃2 小时前
Vitest 自定义 Reporter 与覆盖率卡口:在 Monorepo 里搞增量覆盖率检测
javascript
进击的尘埃2 小时前
E2E 测试里的网络层,到底该怎么 Mock?
javascript
DevUI团队3 小时前
🚀 【Angular】MateChat V20.2.2版本发布,新增8+组件,欢迎体验~
前端·javascript·人工智能
DevUI团队3 小时前
🚀 MateChat V1.11.0 震撼发布!新增工具按钮栏组件及体验问题修复,欢迎体验~
前端·javascript·人工智能
学以智用3 小时前
Vue 3 核心函数全解(组合式 API + 常用工具函数)
javascript·vue.js
滕青山3 小时前
HTTP状态查询 在线工具核心JS实现
前端·javascript·vue.js
SuperEugene4 小时前
Vue3 中后台实战:VXE-Table 从基础表格到复杂业务表格全攻略 | Vue生态精选篇
前端·javascript·vue.js
SuperEugene4 小时前
Vue3 中后台实战:Element + VXE Table 搜索表格分页完整方案 | Vue生态精选篇
前端·javascript·vue.js