首页 > web前端 > js教程 > 正文

如何用JavaScript实现一个待办事项列表_如何管理状态和更新UI?

紅蓮之龍
发布: 2025-12-16 15:23:39
原创
879人浏览过
待办事项列表的核心是状态与UI同步:状态统一存于todos数组,增删改操作均返回新数组,render函数负责重绘UI,事件委托处理动态元素。

如何用javascript实现一个待办事项列表_如何管理状态和更新ui?

用 JavaScript 实现待办事项列表,核心是让数据(状态)和界面(UI)保持同步:添加、完成、删除任务时,既要更新内部数组,又要实时反映在页面上。关键不在写多少代码,而在理清“状态在哪”“谁负责更新”“怎么触发重绘”。

状态统一存放在一个数组里

别把任务散落在 DOM 节点的属性或多个变量中。用一个干净的数组(比如 todos)集中管理所有任务对象:

let todos = [
  { id: 1, text: '买牛奶', completed: false },
  { id: 2, text: '回邮件', completed: true }
];
登录后复制

每个任务带 id(方便精准定位)、text(内容)、completed(完成状态)。增删改都只操作这个数组,不碰 DOM。

用函数封装 UI 渲染逻辑

写一个 render() 函数,它读取当前 todos 数组,清空容器,再遍历生成所有任务的 HTML 并插入:

立即学习Java免费学习笔记(深入)”;

function render() {
  const listEl = document.getElementById('todo-list');
  listEl.innerHTML = todos.map(todo => `
    <li data-id="${todo.id}">
      <input type="checkbox" ${todo.completed ? 'checked' : ''}>
      <span ${todo.completed ? 'style="text-decoration: line-through;"' : ''}>
        ${todo.text}
      </span>
      <button class="delete">×</button>
    </li>
  `).join('');
}
登录后复制

每次状态变化后调用 render(),UI 就自动更新。不用手动找节点改文字或加 class —— 整个列表“重画”更可靠。

晓象AI资讯阅读神器
晓象AI资讯阅读神器

晓象-AI时代的资讯阅读神器

晓象AI资讯阅读神器 72
查看详情 晓象AI资讯阅读神器

事件委托处理动态元素

新添加的任务,其复选框和删除按钮是后来生成的,直接绑事件会失效。用事件委托,在父容器(如 #todo-list)监听,再判断目标:

document.getElementById('todo-list').addEventListener('click', e => {
  const li = e.target.closest('li');
  if (!li) return;

  const id = Number(li.dataset.id);
  if (e.target.classList.contains('delete')) {
    todos = todos.filter(todo => todo.id !== id);
  } else if (e.target.type === 'checkbox') {
    todos = todos.map(todo =>
      todo.id === id ? { ...todo, completed: e.target.checked } : todo
    );
  }
  render(); // 状态变了,立刻重绘
});
登录后复制

添加任务也一样:输入框 + 按钮触发,push 新对象进 todos,再调 render()

避免直接修改原数组,优先用不可变方式

filtermapconcat 等返回新数组的方法,而不是 pushsplice 原地修改。这样能减少意外副作用,也方便未来接入 React 或 Vue 的响应机制:

  • 添加:todos = [...todos, { id: nextId++, text: input.value, completed: false }];
  • 切换完成:todos = todos.map(t => t.id === id ? {...t, completed: !t.completed} : t);
  • 删除:todos = todos.filter(t => t.id !== id);

基本上就这些。状态管住、渲染包圆、事件兜底,待办列表就稳了。

以上就是如何用JavaScript实现一个待办事项列表_如何管理状态和更新UI?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号