0

0

构建 React 费用跟踪应用程序

王林

王林

发布时间:2024-09-11 09:24:18

|

537人浏览过

|

来源于dev.to

转载

构建 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

    Anakin
    Anakin

    一站式 AI 应用聚合平台,无代码的AI应用程序构建器

    下载
    ); }; 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 上查看他的更多项目。

    相关专题

    更多
    js获取数组长度的方法
    js获取数组长度的方法

    在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

    557

    2023.06.20

    js刷新当前页面
    js刷新当前页面

    js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

    416

    2023.07.04

    js四舍五入
    js四舍五入

    js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

    756

    2023.07.04

    js删除节点的方法
    js删除节点的方法

    js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

    479

    2023.09.01

    JavaScript转义字符
    JavaScript转义字符

    JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

    514

    2023.09.04

    js生成随机数的方法
    js生成随机数的方法

    js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

    1091

    2023.09.04

    如何启用JavaScript
    如何启用JavaScript

    JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

    659

    2023.09.12

    Js中Symbol类详解
    Js中Symbol类详解

    javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

    554

    2023.09.20

    c++空格相关教程合集
    c++空格相关教程合集

    本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

    0

    2026.01.23

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Sass 教程
    Sass 教程

    共14课时 | 0.8万人学习

    Bootstrap 5教程
    Bootstrap 5教程

    共46课时 | 3万人学习

    CSS教程
    CSS教程

    共754课时 | 22.9万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

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