当前位置: 首页 > article >正文

JavaScript 本地存储与动态数据渲染实战案例

JavaScript 本地存储与动态数据渲染实战案例一、案例概述在前端开发中本地存储localStorage是无需后端数据库即可实现数据持久化的核心技术动态数据渲染则是前端页面展示数据的基础能力。本案例通过一个轻量化的「待办事项TODO管理工具」结合两者实现完整功能用户添加、删除、标记完成待办事项所有数据自动保存到浏览器本地存储刷新页面后数据不丢失同时通过JavaScript动态将数据渲染到页面。本案例适合前端初学者覆盖JavaScript DOM操作、本地存储API、数据逻辑处理、事件绑定等核心知识点无需依赖任何框架纯原生代码即可运行可直接部署到本地浏览器使用。二、核心技术知识点localStorage本地存储浏览器提供的持久化存储方案存储键值对数据数据永久生效除非手动清除存储容量约5MBDOM操作通过JavaScript获取、创建、修改、删除HTML元素实现页面动态更新事件监听绑定点击、提交等事件实现用户交互响应数据处理数组增删改查、JSON序列化与反序列化localStorage仅支持字符串存储页面初始化刷新页面时自动读取本地数据并渲染。三、实现环境编辑器VS Code任意文本编辑器均可运行环境Chrome/Firefox等现代浏览器技术栈HTML5 CSS3 原生JavaScript无第三方依赖四、完整代码实现!DOCTYPEhtmlhtmllangzh-CNheadmetacharsetUTF-8titleTODO本地存储管理工具/titlestyle*{margin:0;padding:0;box-sizing:border-box;font-family:Arial,sans-serif;}.todo-container{width:500px;margin:50px auto;padding:20px;border:1px solid #eee;border-radius:8px;}.input-box{display:flex;gap:10px;margin-bottom:20px;}#todo-input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:4px;}#add-btn{padding:8px 16px;background:#409eff;color:white;border:none;border-radius:4px;cursor:pointer;}#add-btn:hover{background:#337ecc;}.todo-list{list-style:none;}.todo-item{display:flex;justify-content:space-between;align-items:center;padding:10px;border-bottom:1px solid #eee;}.todo-text{cursor:pointer;}.completed{text-decoration:line-through;color:#999;}.del-btn{color:#f56c6c;cursor:pointer;border:none;background:none;}/style/headbodydivclasstodo-containerh2待办事项管理/h2divclassinput-boxinputtypetextidtodo-inputplaceholder请输入待办事项buttonidadd-btn添加/button/divulclasstodo-listidtodo-list/ul/divscript// 获取DOM元素consttodoInputdocument.getElementById(todo-input);constaddBtndocument.getElementById(add-btn);consttodoListdocument.getElementById(todo-list);// 初始化读取本地存储数据lettodosJSON.parse(localStorage.getItem(todos))||[];// 页面加载时渲染数据window.addEventListener(DOMContentLoaded,renderTodoList);// 添加按钮点击事件addBtn.addEventListener(click,addTodo);// 回车快捷添加todoInput.addEventListener(keydown,(e)e.keyEnteraddTodo());/** * 添加待办事项 */functionaddTodo(){consttexttodoInput.value.trim();if(!text)returnalert(请输入内容);// 创建新待办对象constnewTodo{id:Date.now(),// 唯一IDtext:text,completed:false// 完成状态};todos.push(newTodo);// 追加到数组saveToLocal();// 保存到本地renderTodoList();// 重新渲染页面todoInput.value;// 清空输入框}/** * 渲染待办列表到页面 */functionrenderTodoList(){todoList.innerHTML;// 清空原有内容todos.forEach(todo{constlidocument.createElement(li);li.classNametodo-item${todo.completed?completed:};li.innerHTMLspan classtodo-text>${todo.id}${todo.text}/span button classdel-btn>${todo.id}删除/button;todoList.appendChild(li);});// 绑定状态切换和删除事件bindTodoEvents();}/** * 绑定待办事项交互事件 */functionbindTodoEvents(){// 切换完成状态document.querySelectorAll(.todo-text).forEach(item{item.addEventListener(click,toggleComplete);});// 删除事项document.querySelectorAll(.del-btn).forEach(btn{btn.addEventListener(click,deleteTodo);});}/** * 切换待办事项完成状态 */functiontoggleComplete(e){constidparseInt(e.target.dataset.id);todostodos.map(todo{if(todo.idid)todo.completed!todo.completed;returntodo;});saveToLocal();renderTodoList();}/** * 删除待办事项 */functiondeleteTodo(e){constidparseInt(e.target.dataset.id);todostodos.filter(todotodo.id!id);saveToLocal();renderTodoList();}/** * 保存数据到localStorage */functionsaveToLocal(){localStorage.setItem(todos,JSON.stringify(todos));}/script/body/html五、代码核心解析1. 本地存储数据处理读取数据JSON.parse(localStorage.getItem(todos)) || []本地无数据时返回空数组避免报错保存数据localStorage.setItem(todos, JSON.stringify(todos))将数组转为JSON字符串存储localStorage不支持直接存储对象/数组。2. 动态渲染逻辑每次数据变更添加、删除、状态切换后清空列表容器遍历数据数组重新创建DOM元素通过自定义data-id属性绑定数据唯一标识实现精准操作对应事项。3. 交互功能实现添加功能校验输入内容生成唯一ID追加到数组并保存状态切换点击文本切换completed状态添加删除线样式删除功能过滤掉对应ID的数据更新本地存储。六、功能测试步骤将代码复制到文本编辑器保存为.html文件用浏览器打开该文件输入待办内容点击「添加」或按回车快速添加点击待办文本标记为已完成显示删除线点击「删除」按钮移除对应事项刷新浏览器页面所有数据保持不变验证本地存储生效。七、案例扩展方向增加编辑功能支持修改已添加的待办事项增加筛选功能区分显示全部、未完成、已完成事项增加清空全部功能一键清除所有待办数据样式优化添加动画效果、响应式布局适配移动端。八、总结本案例通过原生JavaScript实现了本地存储与动态数据渲染的完整闭环核心是数据驱动视图所有交互基于数据数组操作视图根据数据自动更新同时通过localStorage完成数据持久化。该模式是前端开发的基础逻辑掌握后可快速上手Vue、React等主流框架也能独立开发轻量化前端工具。

相关文章:

JavaScript 本地存储与动态数据渲染实战案例

JavaScript 本地存储与动态数据渲染实战案例 一、案例概述 在前端开发中,本地存储(localStorage) 是无需后端数据库即可实现数据持久化的核心技术,动态数据渲染则是前端页面展示数据的基础能力。本案例通过一个轻量化的「待办事项…...

OpenCore Configurator:3步完成黑苹果引导配置的终极工具

OpenCore Configurator:3步完成黑苹果引导配置的终极工具 【免费下载链接】OpenCore-Configurator A configurator for the OpenCore Bootloader 项目地址: https://gitcode.com/gh_mirrors/op/OpenCore-Configurator OpenCore Configurator是一款专为黑苹果…...

centos安装部署openclaw

1. 哑铃图是什么? 哑铃图(Dumbbell Plot),有时也称为DNA图或杠铃图,是一种用于比较两个相关数据点的可视化图表。 它源于人们对更有效数据比较方式的持续探索。 在传统的时间序列比较中,我们通常使用两条折…...

Hunyuan Custom模型参数调优与风格迁移实战

1. 探索Hunyuan Custom模型的潜力:单主题深度测试报告作为一名长期关注生成式AI技术的实践者,我最近对腾讯推出的Hunyuan Custom模型进行了系统性测试。这个模型虽然发布已久,却鲜少见到深度评测内容。与Wan VACE等热门模型相比,它…...

aWsm:用Rust实现WebAssembly系统接口,探索轻量级安全计算新范式

1. 项目概述:当WebAssembly遇见操作系统内核最近在开源社区里,一个名为“aWsm”的项目引起了我的注意。它不是一个普通的库或者框架,而是一个用Rust语言编写的、能够运行在Linux内核之上的WebAssembly虚拟机。简单来说,它让WebAss…...

OpenRGB技术解析:如何实现跨厂商RGB设备统一控制的架构设计

OpenRGB技术解析:如何实现跨厂商RGB设备统一控制的架构设计 【免费下载链接】OpenRGB Open source RGB lighting control that doesnt depend on manufacturer software. Supports Windows, Linux, MacOS. Mirror of https://gitlab.com/CalcProgrammer1/OpenRGB. R…...

DeepEval终极实战指南:10分钟构建企业级LLM评测框架

DeepEval终极实战指南:10分钟构建企业级LLM评测框架 【免费下载链接】deepeval The LLM Evaluation Framework 项目地址: https://gitcode.com/GitHub_Trending/de/deepeval 在AI应用爆炸式增长的今天,如何确保大语言模型的质量和可靠性&#xff…...

别再只装Matlab了!MBD汽车控制器开发,这5个Simulink工具箱才是效率翻倍的关键

汽车电子工程师的Simulink工具箱组合指南:精准配置MBD开发环境 当你第一次打开Matlab的工具箱安装界面时,面对数百个选项可能会感到无从下手。作为一位经历过多个量产项目的汽车电子工程师,我完全理解这种选择困难——每个工具箱都看起来很重…...

第103篇:打造你的AI数字分身——从形象克隆到声音复刻的完整指南(操作教程)

文章目录前言环境准备分步操作第一步:搭建SadTalker环境并训练形象模型第二步:使用GPT-SoVITS克隆你的声音第三步:联动生成最终数字分身视频完整代码示例踩坑提示总结前言 最近,AI数字人项目火得一塌糊涂。无论是做知识付费的讲师…...

Python包管理与虚拟环境最佳实践

Python包管理与虚拟环境最佳实践 Python作为一门高效灵活的编程语言,其强大的生态系统依赖于丰富的第三方库。随着项目规模的扩大和依赖库的增加,如何高效管理Python包并隔离不同项目的运行环境成为开发者必须面对的问题。本文将介绍Python包管理与虚拟…...

群晖NAS USB网卡驱动集成解决方案:实现2.5G网络性能扩展

群晖NAS USB网卡驱动集成解决方案:实现2.5G网络性能扩展 【免费下载链接】r8152 Synology DSM driver for Realtek RTL8152/RTL8153/RTL8156 based adapters 项目地址: https://gitcode.com/gh_mirrors/r8/r8152 在数据密集型应用日益普及的今天,…...

别再只盯着特斯拉了!聊聊吉利、小鹏、岚图都在用的‘域控制器’到底是个啥?

从吉利到小鹏:域控制器如何重塑你的智能驾驶体验? 当你在展厅里被吉利星越L的自动泊车功能吸引,或是被小鹏P7的智能座舱震撼时,可能不会想到这些体验背后都藏着一个关键技术——域控制器。这就像智能手机从功能机进化时&#xff0…...

你的旧USB摄像头别扔!Android TV/盒子秒变智能监控(UVC预览实战)

闲置USB摄像头改造指南:让Android TV变身智能监控中心 客厅角落里积灰的旧USB摄像头,或许正等待一次华丽转身。当智能家居监控设备动辄数百元时,很少有人意识到——只需一根OTG线和一个开源库,就能将Android电视盒子变成功能完备…...

5分钟快速上手FF14动画跳过插件:告别冗长副本动画的终极方案

5分钟快速上手FF14动画跳过插件:告别冗长副本动画的终极方案 【免费下载链接】FFXIV_ACT_CutsceneSkip 项目地址: https://gitcode.com/gh_mirrors/ff/FFXIV_ACT_CutsceneSkip 还在为《最终幻想14》国服中冗长的副本动画而烦恼吗?这款专为CN服务…...

E7Helper终极指南:第七史诗自动化助手完整解决方案

E7Helper终极指南:第七史诗自动化助手完整解决方案 【免费下载链接】e7Helper 【Epic Seven Auto Bot】第七史诗多功能覆盖脚本(刷书签🍃,挂讨伐、后记、祭坛✌️,挂JJC等📛,多服务器支持📺&…...

Wan2.2-I2V-A14B参数调优指南:平衡生成质量、时长与显存占用的黄金组合

Wan2.2-I2V-A14B参数调优指南:平衡生成质量、时长与显存占用的黄金组合 1. 理解模型参数的核心影响 Wan2.2-I2V-A14B作为一款高性能文生视频模型,其参数设置直接影响生成效果、处理速度和硬件资源消耗。在RTX 4090D 24GB显存的配置下,我们需…...

漫画图像翻译解决方案:AI驱动的多语言漫画阅读体验

漫画图像翻译解决方案:AI驱动的多语言漫画阅读体验 【免费下载链接】manga-image-translator Translate manga/image 一键翻译各类图片内文字 https://cotrans.touhou.ai/ (no longer working) 项目地址: https://gitcode.com/gh_mirrors/ma/manga-image-translat…...

PPTist:5分钟上手免费开源在线PPT制作工具完全指南

PPTist:5分钟上手免费开源在线PPT制作工具完全指南 【免费下载链接】PPTist PowerPoint-ist(/pauəpɔintist/), An online presentation application that replicates most of the commonly used features of MS PowerPoint, allowing for t…...

表单验证:React-Hook-Form结合Zod的实践

引言 在现代Web开发中,表单验证是用户体验和数据完整性的关键环节。使用React和Material UI构建表单时,结合react-hook-form和zod可以高效地实现表单验证。本文将通过一个实际的产品信息表单示例,展示如何解决表单提交后没有显示错误信息的问题。 问题描述 在使用react-h…...

【Tidyverse 2.0性能革命】:3大底层引擎升级如何让自动化报告提速470%?

更多请点击: https://intelliparadigm.com 第一章:Tidyverse 2.0性能革命的全景认知 Tidyverse 2.0 并非简单版本迭代,而是一场以底层引擎重构为核心的性能范式跃迁。其核心驱动力来自 vctrs 0.6 与 pillar 1.9 的深度协同,以及 …...

从AWS部署到Node.js路由调试

在现代Web开发中,部署应用程序到云服务已经成为一种常见的实践。特别是对于那些刚接触Node.js、Express和AWS的新手开发者来说,部署过程中的问题往往是学习的良好契机。本文将通过一个实际案例,详细介绍如何在AWS环境中调试Node.js应用程序的路由问题。 背景介绍 最近,我…...

【仅限首批内测开发者】PHP 8.9.0-dev类型校验白皮书泄露:strict_objects、typed_properties_v2、covariant_returns三重加固实测数据

更多请点击: https://intelliparadigm.com 第一章:PHP 8.9 类型系统严格校验的演进背景与设计哲学 PHP 8.9 并非官方发布的正式版本(截至 PHP 官方最新稳定版为 8.3),但作为社区广泛探讨的“前瞻性演进构想”&#xf…...

免费抠图软件推荐哪个好用?2026年我试了个遍,最后被这款微信小程序征服了

今年帮朋友打理一个小网店,天天跟商品图打交道,才发现“抠图”这件事有多高频。白底图换透明背景、证件照换底色、把植物宠物抠出来做贴纸……几乎每天都要用。市面上的抠图工具我基本摸了个遍:有些要下载App,有些注册完才发现免费…...

iTerm2配色方案终极指南:450+主题让终端界面焕然一新

iTerm2配色方案终极指南:450主题让终端界面焕然一新 【免费下载链接】iTerm2-Color-Schemes Over 450 terminal color schemes/themes for iTerm/iTerm2. Includes ports to Terminal, Konsole, PuTTY, Xresources, XRDB, Remmina, Termite, XFCE, Tilda, FreeBSD V…...

电容工作原理分析电容电感滤波·

电容电感电容电感 电容电感滤波电容电感 电容工作原理分析电容工作原理分析 电容和电感在滤波电路中发挥关键作用。电容通过充放电特性滤除高频噪声,而电感则利用电磁感应阻碍电流变化来抑制低频干扰。两者的协同工作可实现更稳定的滤波效果。电容工作原理基于电荷存…...

Windows用户必备:3分钟在电脑上直接安装安卓APK的终极方案

Windows用户必备:3分钟在电脑上直接安装安卓APK的终极方案 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 你是否曾经想在Windows电脑上运行安卓应用&#…...

UDS诊断进阶:拆解0x2C动态定义DID的三种用法与五大常见NRC应对策略

UDS诊断进阶:拆解0x2C动态定义DID的三种用法与五大常见NRC应对策略 在汽车电子诊断领域,UDS协议(Unified Diagnostic Services)是开发者必须掌握的核心技术之一。其中0x2C服务(DynamicallyDefineDataIdentifier&#x…...

元宇宙大萧条

一、狂欢后的寒冬:元宇宙大萧条全景2021年,元宇宙概念如同一颗引爆科技圈的核弹,瞬间点燃了资本的狂热。Meta(原Facebook)斥资百亿美元押注Horizon Worlds,微软豪掷700亿美元收购动视暴雪布局元宇宙生态&am…...

Gitea搭配MySQL实战:从Docker Compose一键部署到团队权限精细化管理

Gitea与MySQL容器化协作:企业级代码仓库部署与权限管控指南 当团队规模突破5人时,Git仓库管理就会从"能用就行"升级为"如何高效协作"的工程问题。上周我帮一个8人手游团队迁移到自建Gitea平台时,发现多数教程只教到安装完…...

【.NET 9边缘部署终极指南】:5大跨平台性能瓶颈+3步零配置优化,一线架构师压箱底实践

更多请点击: https://intelliparadigm.com 第一章:.NET 9边缘部署的演进逻辑与场景边界 .NET 9 将边缘计算支持从“可选能力”升级为运行时原生契约,其核心驱动力在于统一轻量级托管环境与硬件感知能力。通过引入 Microsoft.Extensions.Hos…...