使用 JavaScript 类构建可交互的 ToDo List

使用 javascript 类构建可交互的 todo list

本文将指导你如何使用 JavaScript 类来构建一个简单的、可交互的 ToDo List 应用。我们将创建两个类:List 用于管理任务列表,Render 用于处理用户界面 (UI) 的渲染和交互。通过本文,你将学习如何使用面向对象编程 (OOP) 的思想来组织和管理你的代码,并实现一个功能完善的 ToDo List。

ToDo List 类的设计与实现

我们将使用两个类来构建 ToDo List:List 类负责管理任务数据,Render 类负责渲染 UI 和处理用户交互。

List 类

List 类负责存储和管理 ToDo List 中的任务。它包含以下方法:

constructor(render): 构造函数,接收 Render 类的实例作为参数,用于在任务列表发生变化时通知 UI 进行更新。addTask(task): 添加新的任务到 toDo 数组中,并调用 render.renderList() 更新 UI。removeTask(task): 从 toDo 数组中移除指定的任务,并调用 render.renderList() 更新 UI。

class List {  toDo = [];  constructor(render) {    this.render = render;    this.render.renderList(this.toDo);  }  addTask(task) {    this.toDo.push(task);    this.render.renderList(this.toDo);  }  removeTask(task) {    this.toDo = this.toDo.filter((word) => word !== task);    this.render.renderList(this.toDo);  }}

注意事项:

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

toDo 数组用于存储任务列表。addTask 和 removeTask 方法都会调用 render.renderList() 来确保 UI 与数据同步。removeTask 方法使用了 filter 方法创建一个新的数组,其中不包含要删除的任务。 word !== task 这里使用了严格的不等运算符,确保类型和值都不同,避免出现意外情况。

Render 类

Render 类负责处理 UI 的渲染和用户交互。它包含以下方法:

constructor(input): 构造函数,接收包含 ToDo List UI 元素的 DOM 元素作为参数,并绑定事件监听器。renderList(toDo): 接收 toDo 数组作为参数,并根据数组中的任务动态生成 HTML 元素,更新 UI。

class Render {  constructor(input) {    this.input = input;    const taskInput = this.input.querySelector("input");    const addButton = this.input.querySelector("button");    const ul = this.input.querySelector(".tasks");    addButton.addEventListener("click", () => {      const task = taskInput.value.trim();      if (task !== "") {        list.addTask(task);        taskInput.value = "";      }    });    ul.addEventListener("click", (event) => {      if (event.target.tagName === "BUTTON") {        const task = event.target.previousSibling.textContent;        list.removeTask(task);      }    });  }  renderList(toDo) {    const ul = this.input.querySelector(".tasks");    ul.innerHTML = "";    toDo.forEach((task) => {      const li = document.createElement("li");      li.textContent = task;      const deleteButton = document.createElement("button");      deleteButton.textContent = "Delete";      li.appendChild(deleteButton);      ul.appendChild(li);    });  }}

注意事项:

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

构造函数中,我们通过 querySelector 方法获取 input 输入框、添加按钮和 ul 列表等元素,并绑定了点击事件监听器。添加按钮的点击事件处理函数会获取输入框中的任务内容,并调用 list.addTask() 方法添加任务。renderList 方法会清空 ul 列表,然后根据 toDo 数组中的任务动态生成 li 元素,并添加到 ul 列表中。每个 li 元素都包含一个删除按钮,点击删除按钮会调用 list.removeTask() 方法删除任务。trim() 方法用于去除输入框中的空格,避免添加空任务。

HTML 结构

以下是 ToDo List 的 HTML 结构:

                  Document          div {        margin: 80px auto;        text-align: center;      }      input {        width: 20%;      }            

    注意事项:

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

    确保 List.js 和 Render.js 文件已正确引入。to-do-container div 包含了 ToDo List 的所有 UI 元素。tasks ul 列表用于显示任务列表。

    初始化

    最后,我们需要创建 List 和 Render 类的实例,并将它们关联起来:

    const render = new Render(document.querySelector("#to-do-container"));const list = new List(render);

    注意事项:

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

    确保在 HTML 文件加载完成后再执行这段代码,否则可能无法获取到 DOM 元素。

    总结

    通过以上步骤,我们就完成了一个简单的、可交互的 ToDo List 应用。这个示例展示了如何使用 JavaScript 类来组织和管理代码,以及如何使用事件监听器来处理用户交互。你可以根据自己的需求对这个示例进行扩展,例如添加任务优先级、完成状态等功能。

    关键点:

    使用类来组织和管理代码,提高代码的可读性和可维护性。使用事件监听器来处理用户交互,实现动态更新 UI。确保 UI 与数据同步,避免出现不一致的情况。代码的健壮性非常重要,比如处理空输入,错误输入等情况。

    以上就是使用 JavaScript 类构建可交互的 ToDo List的详细内容,更多请关注创想鸟其它相关文章!

    版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
    如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
    发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1510758.html

    (0)
    打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
    上一篇 2025年12月20日 06:10:00
    下一篇 2025年12月20日 06:10:10

    相关推荐

    • Vite + Svelte 中条件动态导入的打包优化策略

      本文探讨在 Vite + Svelte 项目中,如何优化条件动态导入,确保只有实际执行的模块被打包进最终生产构建。通过分析打包器对静态分析的需求,文章详细介绍了利用 Vite 环境变量(import.meta.env)或 @rollup/plugin-replace 等工具,实现可静态分析的条件判断…

      2025年12月20日
      000
    • JavaScript中追踪DOM元素点击状态的教程

      本文将详细讲解如何在JavaScript中准确追踪DOM元素的点击状态。通过引入布尔型状态变量和事件监听器,可以有效解决在不同事件(如mouseover)中判断元素是否曾被点击的需求。教程将提供示例代码,并探讨管理元素交互状态的最佳实践,确保逻辑清晰且易于维护。 理解DOM事件状态追踪的必要性 在前…

      2025年12月20日
      000
    • JavaScript中检测DOM元素点击状态的有效方法

      本文详细介绍了在JavaScript中检测DOM元素点击状态的有效方法。通过使用事件监听器捕获点击事件,并结合布尔型状态变量来记录元素的点击状态,开发者可以在其他事件处理逻辑中准确判断元素是否已被点击,从而实现更灵活的交互控制。教程将提供示例代码和最佳实践,帮助读者优化前端交互逻辑。 理解DOM元素…

      2025年12月20日
      000
    • 使用正则表达式在Cypress中动态断言URL路径及ID的最佳实践

      本文探讨了在Cypress测试中,如何使用正则表达式动态且准确地断言URL路径及其ID。文章详细分析了构建健壮正则表达式的策略,区分了资源名称和数字ID的匹配规则,并提供了两种不同严格程度的正则表达式方案,旨在帮助开发者更有效地验证应用程序的URL路由结构,确保测试的灵活性和准确性。 在前端自动化测…

      2025年12月20日
      000
    • 前端数据按需加载策略:利用两次API调用实现用户详情动态展示

      本教程详细阐述了如何在前端实现用户数据按需加载。通过首次API调用获取用户列表及ID,并在点击“查看详情”按钮时,利用第二次API调用根据用户ID获取完整详情数据,从而优化页面加载性能和用户体验。文章将涵盖HTML结构、JavaScript逻辑、API设计思路及关键代码实现。 在现代Web应用中,高…

      2025年12月20日
      000
    • ElectronJS中精确调整窗口大小以适应DOM元素:解决缩放因子问题

      在ElectronJS应用中,当尝试使用window.resizeTo或Electron特有的setSize/setBounds方法将窗口精确调整为DOM元素的clientWidth和clientHeight时,可能会发现窗口实际尺寸远大于预期。本文揭示了这一问题通常由Electron的持久化zoo…

      2025年12月20日
      000
    • 在 Adobe Illustrator 脚本中实现异步操作的可能性

      在 Adobe Illustrator 脚本开发中,经常会遇到需要分步执行某些函数的需求,例如:prepareToScript、selectTextObjects、mergeTextObjects、moveNamesToNewLayer 或 leaveNamesOnCurrentLayer。开发者可…

      2025年12月20日
      000
    • 实现 Adobe Illustrator 脚本的异步执行

      本文介绍了在 Adobe Illustrator 脚本中实现异步执行的可能性。由于传统的 ExtendScript 缺乏异步/await 支持,因此无法直接实现。文章讨论了 UXP 脚本和 CEP 面板脚本的可能性,但目前 UXP 尚未支持 Illustrator,而 CEP 脚本在访问文档内容时仍…

      2025年12月20日
      000
    • API 请求条件式重试机制:实现与优化

      本文深入探讨了在 Node.js 环境下,如何利用 axios 实现对 API 请求的条件式重试机制。我们将从基础的递归重试方案入手,逐步引入延迟、最大重试次数和异步处理等概念,构建一个健壮且实用的重试函数。文章还将涵盖指数退避、熔断器等高级优化策略,旨在帮助开发者有效应对网络波动、异步操作等场景,…

      2025年12月20日
      000
    • 实现点击页面外部关闭弹出菜单:JavaScript 教程

      本教程详细介绍了如何通过 JavaScript 实现点击页面任意外部区域时自动关闭弹出菜单的功能。通过监听 document 上的点击事件,并结合 e.target.closest() 方法判断点击是否发生在菜单或其触发器之外,从而提升用户体验和界面交互的直观性。 引言:提升用户体验的关键 在现代网…

      2025年12月20日
      000
    • Adobe Illustrator脚本中异步操作的实现与限制

      本文探讨了在Adobe Illustrator脚本中实现异步操作的可行性。核心结论是,传统的ExtendScript(JSX)不支持原生的async/await等异步功能。虽然Adobe UXP脚本和CEP面板提供了现代JavaScript环境,但UXP对Illustrator的文档操作支持有限,而…

      2025年12月20日
      000
    • 自动重试API请求直至满足条件:JavaScript实现指南

      本文旨在指导开发者如何使用JavaScript实现API请求的自动重试机制,直到API响应中的特定值满足预设条件。我们将以axios库为例,展示如何封装一个可复用的重试函数,并提供详细的代码示例和注意事项,帮助您在实际项目中高效地处理需要重试的API调用场景。 实现思路 核心思路是创建一个递归函数,…

      2025年12月20日
      000
    • PHP与MySQL集成:实现成绩系统百分比数据保存

      本教程旨在解决PHP后端与MySQL数据库交互的常见问题,特别是在处理前端AJAX提交的表单数据(如成绩系统中的百分比配置)时。我们将通过优化PHP Actions 类,确保正确建立和使用MySQLi数据库连接,从而实现数据的可靠保存与错误处理,提升系统的健壮性与可维护性。 1. 问题背景与分析 在…

      2025年12月20日
      000
    • 深入理解Next.js中单例模式在中间件与API路由间的行为差异

      本文深入探讨了Next.%ignore_a_1%应用中单例模式在中间件与API路由之间表现出不同实例状态的现象。我们将揭示其核心原因在于Next.js在无服务器(Serverless)环境中为不同功能模块(如中间件和API路由)创建独立的执行上下文,导致单例类在这些独立上下文中被多次初始化。文章提供…

      2025年12月20日
      000
    • React 应用中图片加载优化指南

      本文旨在帮助开发者优化 React 应用中的图片加载速度,解决因图片过大导致的加载缓慢问题。通过分析 Unsplash API 的使用场景,介绍了如何选择合适的图片分辨率,并结合其他优化策略,提升用户体验。本文将提供代码示例和实用技巧,帮助开发者高效地处理图片资源。 在构建 React 应用时,图片…

      2025年12月20日 好文分享
      000
    • React 应用中图片加载优化:提升性能的实用指南

      本文旨在解决 React 应用中使用 Unsplash API 加载图片时遇到的性能问题。通过分析问题根源,即加载过大尺寸的图片,本文提供了优化方案,包括选择合适的图片尺寸、使用图片懒加载、优化图片格式等,帮助开发者显著提升图片加载速度,改善用户体验。 在 react 应用中,高效的图片加载对于提供…

      2025年12月20日 好文分享
      000
    • React 应用中图片加载优化:提升性能的实用技巧

      本文针对React应用中图片加载缓慢的问题,提供了一系列优化方案。通过分析Unsplash API的使用场景,重点讲解了如何选择合适的图片尺寸、实现图片懒加载、以及利用缓存策略等方法,有效提升页面加载速度和用户体验。掌握这些技巧,能显著改善React应用的性能,尤其是在处理大量图片时。 在react…

      2025年12月20日 好文分享
      000
    • React 应用中图片加载优化:从慢速到高效的实践指南

      本文深入探讨了在React应用中处理外部API(如Unsplash)图片加载缓慢的问题。核心解决方案在于选择合适的图片分辨率,避免加载过大的原始图片,从而显著提升页面性能和用户体验。文章将通过代码示例,详细阐述如何优化图片URL选择,并延伸介绍其他重要的图片加载优化策略。 理解图片加载性能瓶颈 在现…

      2025年12月20日 好文分享
      000
    • 动态参数签名的函数调用:使用策略模式实现灵活的业务逻辑

      本文探讨了在JavaScript/TypeScript中,如何优雅地处理根据不同业务场景(如面试类型)调用参数签名不同的函数。通过引入策略设计模式,我们将展示如何定义统一的接口,封装各自的业务逻辑,从而实现代码的解耦、提高可维护性和扩展性,有效解决动态参数传递的挑战。 业务场景与问题描述 在复杂的业…

      2025年12月20日
      000
    • 使用策略模式优雅处理动态函数调用中的参数差异

      本文探讨了在JavaScript/TypeScript中,当根据不同条件需要调用参数签名不同的函数时所面临的挑战。通过引入策略设计模式,我们提供了一种灵活且可扩展的解决方案,允许在统一的接口下处理多样化的函数参数,从而提高代码的可维护性和可读性,避免了复杂的条件判断逻辑。 1. 动态函数调用与参数差…

      2025年12月20日
      000

    发表回复

    登录后才能评论
    关注微信