Vue todoList案例 优化之本地存储

测试代码

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <h1>浏览器本地存储案例</h1>
    <button onclick="saveData()">点击保存数据</button>

</body>
<script>
    function saveData(){
        window.localStorage.setItem("name","张三")
        window.localStorage.setItem("age","18")
        // 保存对象类类型测试
        let student = {'sid':10086,'sname':'张三','age':16}
        window.localStorage.setItem('stu',student)
    }
</script>
</html>

显示效果如下

说明

1- 本次存储是以字符串的方式保存所有数据的

2- 保存对象时,保存的是对象的toString() 方法所输出的内容,格式显示不友好,建议使用 json 来代替

修改代码

复制代码
// 保存对象类类型测试
let student = {'sid':10086,'sname':'张三','age':16}
// window.localStorage.setItem('stu',student)
window.localStorage.setItem('stu',JSON.stringify(student))

显示效果

本地存储的获取和删除

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <h1>浏览器本地存储案例</h1>
    <button onclick="saveData()">点击保存数据</button>
    <button onclick="readData()">点击读取数据</button>
    <button onclick="deleteData()">点击删除数据</button>
    <button onclick="deleteAllData()">点击删除所有数据</button>

</body>
<script>
    function saveData(){
        window.localStorage.setItem("name","张三")
        window.localStorage.setItem("age","18")
        // 保存对象类类型测试
        let student = {'sid':10086,'sname':'张三','age':16}
        window.localStorage.setItem('stu',JSON.stringify(student))
    }
    function readData(){
        console.log(localStorage.getItem("name"))
        console.log(localStorage.getItem("age"))
        let stu = localStorage.getItem("stu")
        console.log(JSON.parse(stu))
    }
    function deleteData(){
        localStorage.removeItem('name')
    }
    function deleteAllData(){
        localStorage.clear()
    }

</script>
</html>

以上是持久化存储,即使浏览器关闭再打开,也会存储到本地

会话级本地存储

sessionStorage

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <h1>浏览器本地存储案例</h1>
    <button onclick="saveData()">点击保存数据</button>
    <button onclick="readData()">点击读取数据</button>
    <button onclick="deleteData()">点击删除数据</button>
    <button onclick="deleteAllData()">点击删除所有数据</button>

</body>
<script>
    function saveData(){
        window.sessionStorage.setItem("name","张三")
        window.sessionStorage.setItem("age","18")
        // 保存对象类类型测试
        let student = {'sid':10086,'sname':'张三','age':16}
        window.sessionStorage.setItem('stu',JSON.stringify(student))
    }
    function readData(){
        console.log(sessionStorage.getItem("name"))
        console.log(sessionStorage.getItem("age"))
        let stu = sessionStorage.getItem("stu")
        console.log(JSON.parse(stu))
    }
    function deleteData(){
        sessionStorage.removeItem('name')
    }
    function deleteAllData(){
        sessionStorage.clear()
    }

</script>
</html>

TODO案例中的本地存储

深度监听 todos 变量

js 复制代码
 watch:{
    todos:{
      deep:true,
      handler(value){
        localStorage.setItem('todos',JSON.stringify(value))
      }
    }
  }

todos 的数据获取

js 复制代码
data() {
    return {
      todos:JSON.parse(localStorage.getItem('todos')) || []
    }
  },
相关推荐
Highcharts.js1 天前
缺失数据可视化图表开发实战|Highcharts创建人员出生统计面积图表示例
开发语言·前端·javascript·信息可视化·highcharts·图表开发
LaughingZhu1 天前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
怕浪猫1 天前
Electron 开发实战(一):从零入门核心基础与环境搭建
前端·electron·ai编程
小鹏linux1 天前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
前端若水1 天前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger1 天前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
涵涵(互关)1 天前
Naive-ui树型选择器只显示根节点
前端·ui·vue
BY组态1 天前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态1 天前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态
SoaringHeart1 天前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter