使用 React 构建主题切换的 Todo 应用程序

使用 react 构建主题切换的 todo 应用程序

介绍

在本教程中,我们将使用 react 构建一个 待办事项列表 web 应用程序。该项目有助于理解状态管理、事件处理以及在 react 中使用列表。对于想要增强 react 开发技能的初学者来说,它是完美的选择。

项目概况

待办事项列表应用程序允许用户添加、标记为已完成和删除任务。它提供了一个干净的界面来管理日常任务。该项目展示了如何使用 react 来管理简单而动态的应用程序的状态。

特征

添加新任务:用户可以将任务添加到列表中。标记为已完成:用户可以将任务标记为已完成。删除任务:用户可以从列表中删除任务。本地存储:使用 localstorage 在页面重新加载时保留任务。

使用的技术

react:用于构建用户界面和管理组件状态。css:用于设计应用程序的样式。javascript:核心逻辑和功能。

项目结构

项目结构遵循典型的 react 项目布局:

├── public├── src│   ├── components│   │   ├── todolist.jsx│   │   ├── todoitem.jsx│   ├── app.jsx│   ├── app.css│   ├── index.js│   └── index.css├── package.json└── readme.md

关键部件

todolist.jsx:处理待办事项列表的显示和管理。todoitem.jsx:管理单个待办事项,包括将它们标记为已完成或删除它们。

代码说明

待办事项列表组件

该组件处理整个待办事项列表的状态,包括添加新任务和渲染列表。

import { usestate, useeffect } from "react";import todoitem from "./todoitem";const todolist = () => {  const [task, settask] = usestate("");  const [tasks, settasks] = usestate([]);  useeffect(() => {    const savedtasks = json.parse(localstorage.getitem("tasks")) || [];    settasks(savedtasks);  }, []);  useeffect(() => {    localstorage.setitem("tasks", json.stringify(tasks));  }, [tasks]);  const addtask = () => {    if (task.trim()) {      settasks([...tasks, { text: task, completed: false }]);      settask("");    }  };  const togglecompletion = (index) => {    const newtasks = tasks.map((t, i) =>      i === index ? { ...t, completed: !t.completed } : t    );    settasks(newtasks);  };  const deletetask = (index) => {    const newtasks = tasks.filter((_, i) => i !== index);    settasks(newtasks);  };  return (    

todo list

settask(e.target.value)} placeholder="add a new task" />
    {tasks.map((t, index) => ( ))}
);};export default todolist;

todoitem 组件

todoitem 组件管理每个任务的显示,以及将其标记为已完成或删除的选项。

const todoitem = ({ task, index, togglecompletion, deletetask }) => {  return (    
  • togglecompletion(index)}>{task.text}
  • );};export default todoitem;

    在此组件中,我们从父 todolist 接收 props 并处理诸如切换任务完成或删除任务之类的操作。

    应用程序组件

    app.jsx 作为应用程序的根,渲染 todolist 组件。

    import  { usestate } from "react";import "./app.css";import todolist from './components/todolist';import sun from "./assets/images/icon-sun.svg";import moon from "./assets/images/icon-moon.svg";const app = () => {  const [islighttheme, setislighttheme] = usestate(false);  const toggletheme = () => {    setislighttheme(!islighttheme);  };  return (    

    todo

    @@##@@

    made with ❤️ by abhishek gurjar

    拍客piikee竞拍系统
    拍客piikee竞拍系统

    拍客竞拍系统是一款免费竞拍网站建设软件,任何个人可以下载使用,但未经商业授权不能进行商业活动,程序源代码开源,任何个人和企业可以进行二次开发,但不能以出售和盈利为目的。安装方法,将www文件夹里面的所有文件上传至虚拟主机,在浏览器执行http://你的域名/install.php或者直接导入数据库文件执行。本次升级优化了一下内容1,程序和模板完美分离。2,优化了安装文件。3,后台增加模板切换功能。

    拍客piikee竞拍系统 0
    查看详情 拍客piikee竞拍系统
    );};export default app;

    css 样式

    css 确保待办事项列表应用程序用户友好且响应迅速。

    * {  box-sizing: border-box;}body {  margin: 0;  padding: 0;  font-family: josefin sans, sans-serif;}.app {  width: 100%;  height: 100vh;  background-color: #161722;  color: white;  background-image: url(./assets//images/bg-desktop-dark.jpg);  background-repeat: no-repeat;  background-size: contain;  background-position-x: center;  background-position-y: top;  display: flex;  align-items: center;  justify-content: flex-start;  flex-direction: column;}.header {  width: 350px;  margin-top: 20px;  display: flex;  align-items: center;  justify-content: space-between;}.title h1 {  font-size: 30px;  letter-spacing: 7px;}.mode {  display: flex;  align-items: center;  justify-content: center;}.mode img {  width: 22px;}.todo {  width: 350px;  flex-direction: column;  display: flex;  align-items: center;  justify-content: flex-start;}.input-box {  border-bottom: 1px solid white;  display: flex;  align-items: center;  justify-content: center;  background-color: #25273c;  width: 100%;  gap: 10px;  padding: 8px;  border-radius: 10px;}.check-circle {  width: 12px;  height: 12px;  border-radius: 50%;  border: 1px solid white;  display: flex;  align-items: center;  justify-content: center;  background-image: linear-gradient(to right,hsl(230, 50%, 20%) , hsl(280, 46%, 28%));}.input-task {  width: 90%;  border: none;  color: white;  background-color: #25273c;}.input-task:focus {  outline: none;}.todo-list {  margin-top: 20px;  width: 350px;  background-color: #25273c;}.todo-box {  margin-inline: 15px;  margin-block: 10px;  width: 100%;  display: flex;  align-items: center;  justify-content: flex-start;  gap: 15px;}.todo-box .cross{width: 14px;}.details {  margin-bottom: 40px;border-bottom: 1px solid white;  width: 350px;  display: flex;  align-items: center;  justify-content: space-evenly;  background-color: #25273c;  font-size: 12px;  padding: 12px;  border-bottom-right-radius: 7px;  border-bottom-left-radius: 7px;}.details .clickbtn{  cursor: pointer;}.details .clickbtn:hover{color: #3074fd;}/* //light theme  */.light-theme .app {  background-color: #fff;  color: #000;  background-image: url(./assets//images/bg-desktop-light.jpg);}.light-theme .header {color: white;}.light-theme .input-box{  background-color: white;  color: black;  border-bottom: 1px solid black;}.light-theme input{  background-color: white;  color: black;}.light-theme .check-circle{  border:1px solid black;}.light-theme  .todo-list{  background-color: white;  color: black;}.light-theme .details{  border-bottom: 1px solid black;  background-color: white;  color: black;}.footer{ margin: 40px;}

    这些样式确保待办事项列表简单干净,同时允许任务管理。

    安装与使用

    首先,克隆存储库并安装依赖项:

    git clone https://github.com/abhishekgurjar-in/todo_list.gitcd todo-listnpm installnpm start

    应用程序将在 http://localhost:3000 开始运行。

    现场演示

    在此处查看待办事项列表的现场演示。

    结论

    todo list 项目是练习在 react 中使用状态、列表和事件处理的好方法。它演示了如何构建一个有用的应用程序,可以使用 localstorage 跨会话保存数据。

    制作人员

    灵感:受到对简单有效的任务管理工具的需求的启发。

    作者

    abhishek gurjar 是一位充满热情的 web 开发人员。你可以在 github 上查看他的更多项目。

    theme-icon

    以上就是使用 React 构建主题切换的 Todo 应用程序的详细内容,更多请关注创想鸟其它相关文章!

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

    (0)
    打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
    上一篇 2025年12月24日 12:47:54
    下一篇 2025年12月24日 12:48:07

    相关推荐

    • 构建 React 费用跟踪应用程序

      介绍 在本教程中,我们将使用 react 创建一个 expense tracker web 应用程序。该项目将帮助您了解 react 中的状态管理、事件处理和动态列表更新。对于旨在通过构建实用且有用的应用程序来加强 react 开发知识的初学者来说,它是理想的选择。 项目概况 费用跟踪应用程序允许用…

      2025年12月24日 好文分享
      000
    • 月相 | CSS 艺术:空间

      CSS 艺术:互动空间场景 这是前端挑战 v24.09.04,CSS 艺术:空间的提交。 灵感 对于这个挑战,我想捕捉夜空的动态和互动性质。不断变化的月相、闪烁的星星,以及偶尔令人兴奋的流星,一直让人类着迷。通过创建这些天体现象的动画和交互式表示,我的目标是将宇宙的一小部分带到我们的屏幕上,提醒我们…

      2025年12月24日
      000
    • 使用 Tailwind CSS 创建流星边框动画

      在这篇博文中,我们将使用 tailwind css 创建一个迷人的“流星”边框动画。此效果为输入字段提供发光的动画边框,可以吸引用户的注意力 – 非常适合电子邮件注册或重要通知等号召性用语部分。 演示 在深入研究代码之前,您可以在此处查看效果的现场演示:在 tailwind playgr…

      2025年12月24日
      000
    • HTML、CSS 和 JavaScript 项目

      欢迎来到我的 html、css 和 javascript 项目集合!这篇博文全面概述了我创建的各种项目,展示了 web 开发的不同方面。每个项目都可以在自己的存储库中找到,其中包含您需要探索和学习的所有代码。 目录 简介项目概况开始使用贡献作者 介绍 作为一名 web 开发人员,我喜欢从事各种项目,…

      2025年12月24日
      000
    • Riva – Tailwind CSS 仪表板模板生成器

      大家好! 我想向您介绍 Riva Dashboard,这是一个用于 Tailwind CSS 的拖放式仪表板模板生成器,旨在帮助开发人员加快开发过程。 Riva 构建于 Tailwind CSS 之上,具有以下功能,包含 72 多个组件(更多组件即将推出)。 链接: 立即学习“前端免费学习笔记(深入…

      2025年12月24日
      000
    • 介绍我的新 Bootstrap olor 调色板生成工具

      嘿,开发者社区! ? 我很高兴分享我一直在开发的一个新工具,它将使您的网页设计过程更加顺畅和更加个性化。如果您发现自己想要更多地控制网站的配色方案,那么这个工具适合您! ? 它有什么作用? 这个 Bootstrap 5 调色板生成器工具可让您轻松设置自己的调色板。只需点击几下,您就可以定义主要、次要…

      2025年12月24日
      000
    • 带有媒体查询的响应式网页设计

      第 6 讲:带有媒体查询的响应式网页设计 在本次讲座中,我们将深入探讨响应式网页设计,这是创建在从台式机到智能手机的所有设备上看起来都很棒的网站的关键技能。响应式设计的关键是使用媒体查询,它允许您根据屏幕尺寸或设备特性应用不同的样式。 了解响应式网页设计 响应式网页设计可确保您的网站适应各种屏幕尺寸…

      2025年12月24日
      000
    • 如何将 CSS 样式添加到 HTML 页面:初学者指南

      简介想象一下您在厨房里,准备准备一道菜。主要成分 (html) 摆在您面前:肉、蔬菜、香料。但要将这些食材转化为烹饪杰作,您需要烹饪技术、调味料和摆盘——这就是 css(层叠样式表)发挥作用的地方。 css 就像网络的“调味艺术”:没有它,您的 html 页面将会很有营养,但有点乏味。在本指南中,我…

      2025年12月24日
      000
    • How to create typography tokens for a design system using Sass mixins

      许多设计系统都是从颜色和尺寸等基本设计标记开始的,这些标记可以轻松转换为 css 变量(或 sass 或 less 等)。 // tokens.scss$primary-text-color: #aaa;$secondary-text-color: #ccc;$size-s: 8px;$size-m…

      2025年12月24日
      000
    • 仅使用 CSS 从图像中删除背景

      注意:我刚刚翻译了下面的文字并将其发布在这里。参考文献位于本文末尾。 在这篇适合初学者的博客文章中,我们将学习如何仅使用 css(特别是 css 属性 mix-blend-mode)从图像中删除背景。此技术可用于创建有趣的视觉效果并通过减少编辑图像的需求来提高网站的性能。 为什么这个技巧很重要? 下…

      2025年12月24日
      000
    • CSS 过渡和动画

      第 7 讲:css 过渡和动画 在本次讲座中,我们将探索如何使用 css 过渡和动画让您的网页栩栩如生。这些技术允许您创建流畅、引人入胜的效果,从而增强用户体验,而无需 javascript。 css 过渡简介 css 转换使您能够在指定的持续时间内平滑地更改属性值。它们非常适合创建悬停效果、按钮动…

      2025年12月24日
      000
    • 终极 Reactjs 备忘单:轻松掌握 Reactjs⚛️

      介绍 react.js 已成为现代 web 开发中用于创建交互式和动态用户界面的主要内容。其基于组件的架构通过提供声明性 ui 并利用虚拟 dom 的概念,简化了单页应用程序 (spa) 的开发。本备忘单旨在指导您了解 react.js 的基本知识,从了解基础知识到掌握高级技术。无论您是初学者还是希…

      2025年12月24日
      000
    • 为什么多年的经验让我选择全栈而不是平均栈

      在全栈和平均栈开发方面工作了 6 年多,我可以告诉您,虽然这两种方法都是流行且有效的方法,但它们满足不同的需求,并且有自己的优点和缺点。这两个堆栈都可以帮助您创建 Web 应用程序,但它们的实现方式却截然不同。如果您在两者之间难以选择,我希望我在两者之间的经验能给您一些有用的见解。 在这篇文章中,我…

      2025年12月24日
      000
    • CSS 中的网格和 Flex 布局

      介绍 flexbox 和网格布局都是强大的布局。 弹性盒: flexbox 是一种一维布局模型,最适合在单行或单列中排列元素。当元素的大小或容器的大小未知时,flexbox 特别有用。它非常适合水平和垂直对齐项目,并且对于创建导航栏、侧边栏或工具栏非常有用。 css 网格: 网格是一种二维布局模型,…

      2025年12月24日
      000
    • CSS 网格 – 深入探讨

      第 9 讲:css 网格 – 深入探讨 欢迎来到《从基础到辉煌》课程第九讲。在本次讲座中,我们将探索 css 网格,这是一个强大的布局系统,可让您轻松创建复杂的网页布局。虽然 flexbox 非常适合单维布局(行或列),但 css grid 提供了二维布局系统,使您能够同时控制行和列。 …

      2025年12月24日
      000
    • 掌握 Web 动画:CSS 与未优化和优化的 JavaScript 性能

      网页动画可以显着改善用户体验,但如果实施不仔细,也会影响网站性能。在本文中,我将比较三种不同的方法来对大小脉冲的圆形元素进行动画处理。我将使用 css、未优化的 javascript 和优化的 javascript,并向您展示如何使用 chrome devtools 衡量它们的性能。 网页动画简介 …

      2025年12月24日
      000
    • 仅使用 CSS 实时测试 HTML 和 CSS 的实用方法

      最近,我公开了一个我为创建放射状设计而开发的 CSS 框架。在开发过程中,我遇到了一些挑战,包括测试不同的功能。我注意到 CSS linter 和其他工具不允许我了解为什么某些东西不起作用,即使没有基本错误。另一个典型的 CSS 问题是如何在不同的浏览器之间共享它。幸运的是,我发现某些新的 CSS …

      2025年12月24日
      000
    • React 中的 CSS 冲突

      ui 是我们开始输入逻辑以完成前端之前的第一步。因此,我们编写标记,然后编写获得所需用户界面所需的基本样式。在编写标记时,我们必须创建有意义的类名来寻址和访问 html 标记并向其添加样式。通过简单的用户界面和不同的标签,我们可以或多或少轻松地做到这一点。在编写重复且复杂的 ui 时,给出有意义且独…

      2025年12月24日 好文分享
      000
    • 免费 Vanilla CSS 模板的最佳网站

      这是最好的网站的综述,您可以在其中找到并下载免费的 css 模板。我们专注于不使用任何框架的普通 css 模板。这些高质量的项目将为您的网站、登陆页面、博客和作品集提供支持。 在线空间中有许多模板创建者。以下是让下面提到的这些人脱颖而出的原因。 模板免费提供给个人和商业用途项目看起来很现代,并提供强…

      2025年12月24日 好文分享
      000
    • 《Insect Particlizer》像素操作与 CSS 结合的实验

      canvas..多么美丽的名字,并不能表达我对这个api的喜爱程度,虽然一开始对我来说很糟糕,但经过一些尝试和错误,我理解了它,甚至尝试用它创建不常见的东西这让我的 ide 崩溃了好几次。这里的这个实验只是我在前端之旅中经常做的无数实验之一,在这里我使用 canvas api 来获取昆虫图像的数据,…

      2025年12月24日
      000

    发表回复

    登录后才能评论
    关注微信