当前位置:首页 > 文章列表 > 文章 > 前端 > 构建 React 费用跟踪应用程序

构建 React 费用跟踪应用程序

来源:dev.to 2024-09-11 16:13:00 0浏览 收藏

珍惜时间,勤奋学习!今天给大家带来《构建 React 费用跟踪应用程序》,正文内容主要涉及到等等,如果你正在学习文章,或者是对文章有疑问,欢迎大家关注我!后面我会持续更新相关内容的,希望都能帮到正在学习的大家!

构建 React 费用跟踪应用程序

介绍

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

项目概况

费用跟踪应用程序允许用户跟踪他们的收入和费用。它通过分类和计算收入、支出和总余额来帮助管理财务数据。该项目展示了如何使用 react 来有效管理状态和处理用户输入。

特征

  • 添加交易:用户可以添加收入或支出交易。
  • 跟踪余额:用户可以动态查看其总余额并跟踪变化。
  • 删除交易:用户可以从列表中删除交易。
  • 本地存储:使用 localstorage 在页面重新加载时保留事务。

使用的技术

  • react:构建用户界面并管理组件状态。
  • css:设置应用程序的样式。
  • javascript:处理应用程序的核心逻辑。

项目结构

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

├── public
├── src
│   ├── components
│   │   ├── transactionlist.jsx
│   │   ├── transactionitem.jsx
│   │   ├── addtransaction.jsx
│   ├── app.jsx
│   ├── app.css
│   ├── index.js
│   └── index.css
├── package.json
└── readme.md

关键部件

  • transactionlist.jsx:显示和管理交易列表。
  • transactionitem.jsx:代表单个交易。
  • addtransaction.jsx:处理添加新交易(收入或支出)。

代码说明

交易列表组件

该组件负责显示交易并管理所有交易的状态。

import { usestate, useeffect } from "react";
import transactionitem from "./transactionitem";

const transactionlist = () => {
  const [transactions, settransactions] = usestate([]);

  useeffect(() => {
    const savedtransactions = json.parse(localstorage.getitem("transactions")) || [];
    settransactions(savedtransactions);
  }, []);

  useeffect(() => {
    localstorage.setitem("transactions", json.stringify(transactions));
  }, [transactions]);

  const deletetransaction = (index) => {
    const newtransactions = transactions.filter((_, i) => i !== index);
    settransactions(newtransactions);
  };

  return (
    

transaction history

    {transactions.map((transaction, index) => ( ))}
); }; export default transactionlist;

交易项目组件

transactionitem 组件代表单个事务,包括删除它的选项。

const transactionitem = ({ transaction, deletetransaction }) => {
  const sign = transaction.amount < 0 ? "-" : "+";
  return (
    
  • {transaction.text} {sign}${math.abs(transaction.amount)}
  • ); }; export default transactionitem;

    添加交易组件

    该组件管理添加新交易,允许用户输入收入或支出数据。

    import { usestate } from "react";
    
    const addtransaction = ({ addtransaction }) => {
      const [text, settext] = usestate("");
      const [amount, setamount] = usestate("");
    
      const handlesubmit = (e) => {
        e.preventdefault();
        const transaction = { text, amount: +amount };
        addtransaction(transaction);
        settext("");
        setamount("");
      };
    
      return (
        

    add new transaction

    settext(e.target.value)} placeholder="enter description" /> setamount(e.target.value)} placeholder="enter amount" />
    ); }; export default addtransaction;

    应用程序组件

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

    import { usestate } from "react";
    import transactionlist from './components/transactionlist';
    import addtransaction from './components/addtransaction';
    import './app.css';
    
    const app = () => {
      const [transactions, settransactions] = usestate([]);
    
      const addtransaction = (transaction) => {
        settransactions([...transactions, transaction]);
      };
    
      return (
        

    expense tracker

    made with ❤️ by abhishek gurjar

    ); }; export default app;

    css 样式

    css 确保应用程序看起来干净且用户友好。

    body {
      font-family: arial, sans-serif;
      background-color: #f4f4f4;
    }
    
    .app {
      width: 400px;
      margin: 50px auto;
      background-color: #fff;
      padding: 20px;
      box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    }
    
    h1 {
      text-align: center;
    }
    
    input {
      width: calc(100% - 10px);
      padding: 5px;
      margin-bottom: 10px;
    }
    
    button {
      width: 100%;
      padding: 10px;
      background-color: #007bff;
      color: #fff;
      border: none;
      cursor: pointer;
    }
    
    button:hover {
      background-color: #0056b3;
    }
    
    .transaction-list ul {
      list-style: none;
      padding: 0;
    }
    
    .transaction-list li {
      background-color: #f9f9f9;
      margin: 5px 0;
      padding: 10px;
      border-left: 5px solid green;
    }
    
    .transaction-list li.expense {
      border-left: 5px solid red;
    }
    
    .transaction-list span {
      float: right;
    }
    
    button {
      float: right;
      background-color: red;
      color: white;
      padding: 5px;
    }
    .footer{
        text-align: center;
        margin: 40px;
    }
    

    安装与使用

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

    git clone https://github.com/abhishekgurjar-in/expense-tracker.git
    cd expense-tracker
    npm install
    npm start
    

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

    现场演示

    在此处查看费用跟踪器的现场演示。

    结论

    expense tracker 项目演示了如何在 react 中有效管理列表和状态。这是学习如何使用 localstorage 构建具有持久数据存储的动态应用程序的好方法。

    制作人员

    • 灵感:旨在帮助用户跟踪其金融交易。

    作者

    abhishek gurjar 是一位专注的 web 开发人员,热衷于创建实用且功能性的 web 应用程序。在 github 上查看他的更多项目。

    理论要掌握,实操不能落!以上关于《构建 React 费用跟踪应用程序》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

    版本声明
    本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
    使用所见即所得 HTML 编辑器简化大学内容管理使用所见即所得 HTML 编辑器简化大学内容管理
    上一篇
    使用所见即所得 HTML 编辑器简化大学内容管理
    讯飞听见怎么删除录音-讯飞听见删除录音的方法
    下一篇
    讯飞听见怎么删除录音-讯飞听见删除录音的方法
    查看更多
    最新文章
    查看更多
    课程推荐
    • 前端进阶之JavaScript设计模式
      前端进阶之JavaScript设计模式
      设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
      542次学习
    • GO语言核心编程课程
      GO语言核心编程课程
      本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
      508次学习
    • 简单聊聊mysql8与网络通信
      简单聊聊mysql8与网络通信
      如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
      497次学习
    • JavaScript正则表达式基础与实战
      JavaScript正则表达式基础与实战
      在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
      487次学习
    • 从零制作响应式网站—Grid布局
      从零制作响应式网站—Grid布局
      本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
      484次学习
    查看更多
    AI推荐
    • AI Make Song:零门槛AI音乐创作平台,助你轻松制作个性化音乐
      AI Make Song
      AI Make Song是一款革命性的AI音乐生成平台,提供文本和歌词转音乐的双模式输入,支持多语言及商业友好版权体系。无论你是音乐爱好者、内容创作者还是广告从业者,都能在这里实现“用文字创造音乐”的梦想。平台已生成超百万首原创音乐,覆盖全球20个国家,用户满意度高达95%。
      18次使用
    • SongGenerator.io:零门槛AI音乐生成器,快速创作高质量音乐
      SongGenerator
      探索SongGenerator.io,零门槛、全免费的AI音乐生成器。无需注册,通过简单文本输入即可生成多风格音乐,适用于内容创作者、音乐爱好者和教育工作者。日均生成量超10万次,全球50国家用户信赖。
      14次使用
    •  BeArt AI换脸:免费在线工具,轻松实现照片、视频、GIF换脸
      BeArt AI换脸
      探索BeArt AI换脸工具,免费在线使用,无需下载软件,即可对照片、视频和GIF进行高质量换脸。体验快速、流畅、无水印的换脸效果,适用于娱乐创作、影视制作、广告营销等多种场景。
      14次使用
    • SEO标题协启动:AI驱动的智能对话与内容生成平台 - 提升创作效率
      协启动
      SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
      17次使用
    • Brev AI:零注册门槛的全功能免费AI音乐创作平台
      Brev AI
      探索Brev AI,一个无需注册即可免费使用的AI音乐创作平台,提供多功能工具如音乐生成、去人声、歌词创作等,适用于内容创作、商业配乐和个人创作,满足您的音乐需求。
      19次使用
    微信登录更方便
    • 密码登录
    • 注册账号
    登录即同意 用户协议隐私政策
    返回登录
    • 重置密码