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

}

}

}

相关推荐
yuehua_zhang1 小时前
uni app 的app端 写入运行日志到指定文件夹。
前端·javascript·uni-app
EndingCoder4 小时前
调试技巧:Chrome DevTools 与 Node.js Inspector
javascript·网络·electron·node.js·vim·chrome devtools
知识分享小能手4 小时前
React学习教程,从入门到精通, React 入门指南:React JSX 语法知识点详解及案例代码(8)
前端·javascript·vue.js·学习·react.js·前端框架·anti-design-vue
学习3人组4 小时前
React 组件基础与事件处理
前端·javascript·react.js
qczg_wxg8 小时前
React Native的动画系统
javascript·react native·react.js
漂流瓶jz9 小时前
解锁Babel核心功能:从转义语法到插件开发
前端·javascript·typescript
大怪v10 小时前
老乡,别走!Javascript隐藏功能你知道吗?
前端·javascript·代码规范
ERP老兵-冷溪虎山10 小时前
Python/JS/Go/Java同步学习(第三篇)四语言“切片“对照表: 财务“小南“纸切片术切凭证到崩溃(附源码/截图/参数表/避坑指南/老板沉默术)
java·javascript·python·golang·中医编程·四语言同步学习·职场生存指南
webYin10 小时前
vue2 打包生成的js文件过大优化
前端·vue.js·webpack
gnip10 小时前
结合Worker通知应用更新
前端·javascript