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))

}

}

}

相关推荐
哆啦A梦158813 小时前
搜索页面布局
前端·vue.js·node.js
_院长大人_14 小时前
el-table-column show-overflow-tooltip 只能显示纯文本,无法渲染 <p> 标签
前端·javascript·vue.js
SevgiliD14 小时前
el-table中控制单列内容多行超出省略及tooltip
javascript·vue.js·elementui
要加油哦~14 小时前
JS | 知识点总结 - 原型链
开发语言·javascript·原型模式
哆啦A梦158815 小时前
axios 的二次封装
前端·vue.js·node.js
阿珊和她的猫15 小时前
深入理解与手写发布订阅模式
开发语言·前端·javascript·vue.js·ecmascript·状态模式
爱看书的小沐16 小时前
【小沐杂货铺】基于Three.js渲染三维风力发电机(WebGL、vue、react、WindTurbine)
javascript·vue.js·webgl·three.js·opengl·风力发电机·windturbine
qq_3985865416 小时前
Threejs入门学习笔记
javascript·笔记·学习
浪裡遊17 小时前
Nivo图表库全面指南:配置与用法详解
前端·javascript·react.js·node.js·php
課代表17 小时前
JavaScript 二维数组的三种定义与初始化方法
javascript·初始化·二维数组·多维数组·动态数组·循环遍历·数组合并