【React】记账本项目

1.环境搭建

在这里插入图片描述

npx create-react-app react-bill-demo
cd react-bill-demo
npm i @reduxjs/toolkit  react-redux react-router-dom dayjs classnames antd-mobile axios

2. 记账本 - 配置别名路径@

1.路径解析配置(webpack)
2. 路径联想配置(VsCode)

3.记账本 - 数据Mock实现

1.什么是数据Mock
在前后端分类的开发模式下,前端可以在没有实际后端接口的支持下先进行接口数据的模拟,进行正常的业务功能开发
在这里插入图片描述

json-server实现数据Mock

在这里插入图片描述

在这里插入图片描述

json文件

{
  "ka": [
    {
      "type": "pay",
      "money": -99,
      "date": "2022-10-24 10:36:42",
      "useFor": "drinks",
      "id": 1
    },
    {
      "type": "pay",
      "money": -88,
      "date": "2022-10-24 10:37:51",
      "useFor": "longdistance",
      "id": 2
    },
    {
      "type": "income",
      "money": 100,
      "date": "2022-10-22 00:00:00",
      "useFor": "bonus",
      "id": 3
    },
    {
      "type": "pay",
      "money": -33,
      "date": "2022-09-24 16:15:41",
      "useFor": "dessert",
      "id": 4
    },
    {
      "type": "pay",
      "money": -56,
      "date": "2022-10-22T05:37:06.000Z",
      "useFor": "drinks",
      "id": 5
    },
    {
      "type": "pay",
      "money": -888,
      "date": "2022-10-28T08:21:42.135Z",
      "useFor": "travel",
      "id": 6
    },
    {
      "type": "income",
      "money": 10000,
      "date": "2023-03-20T06:45:54.004Z",
      "useFor": "salary",
      "id": 7
    },
    {
      "type": "pay",
      "money": -10,
      "date": "2023-03-22T07:17:12.531Z",
      "useFor": "drinks",
      "id": 8
    },
    {
      "type": "pay",
      "money": -20,
      "date": "2023-03-22T07:51:20.421Z",
      "useFor": "dessert",
      "id": 9
    },
    {
      "type": "pay",
      "money": -100,
      "date": "2023-03-22T09:18:12.898Z",
      "useFor": "drinks",
      "id": 17
    },
    {
      "type": "pay",
      "money": -50,
      "date": "2023-03-23T09:11:23.312Z",
      "useFor": "food",
      "id": 18
    },
    {
      "type": "pay",
      "money": -10,
      "date": "2023-04-03T11:14:56.036Z",
      "useFor": "food",
      "id": 19
    }
  ]
}

4.记账本 - 整体路由设计

在这里插入图片描述

记得在index.js文件中注入

import React from 'react';
import ReactDOM from 'react-dom/client';
import './index.css';
import { RouterProvider } from 'react-router-dom'
import router from '@/router/index'
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(
    <RouterProvider router={router}></RouterProvider>
);

5.记账本 - antD-mobile主题定制

在这里插入图片描述
antd-mobile官网文档

6. 记账本 - Redux管理账目列表

在这里插入图片描述
在这里插入图片描述
命令的合并,参考我的博文

7.记账本 - TabBar功能实现

在这里插入图片描述
安装sass

npm i -D sass

8.记账本 - 月度账单 - 统计区域

1.点击切换选择框功能实现

在这里插入图片描述

 <DatePicker
            className="kaDate"
            title="记账日期"
            precision="month"
            visible={visible}
            max={new Date()}
            onConfirm={val => {
          		console.log(val)
        	}}
            onCancel={()=>{
             	 setVisible(false)
            }}
            onClose={() => {
          		setVisible(false)
        }}
2.点击确定切换时间显示

在这里插入图片描述

 <span className="text">
      {dayjs(currentDate).format('YYYY | MM' )}月账单
 </span>
3.账单数据按月分组实现

在这里插入图片描述

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React项目的职责主要包括以下几个方面: 1. UI组件开发:React是一个用于构建用户界面的JavaScript库,项目中的开发人员使用React来创建可重用的UI组件。这些组件可以包括按钮、表单、导航栏等等,用于构建整个应用的用户界面。 2. 状态管理:React项目通常使用状态管理库(如Redux、Mobx等)来管理应用的状态。开发人员需要定义和维护应用的状态,并确保状态的一致性和可追踪性。 3. 路由管理:对于较大规模的React项目,通常需要使用路由库(如React Router)来管理不同页面之间的导航和路由。开发人员需要配置和维护应用的路由规则,并确保页面之间的跳转和参数传递正常工作。 4. 数据请求和处理:React项目通常需要与后端API进行数据交互,开发人员需要使用适当的工具(如axios、fetch等)发送HTTP请求,并处理返回的数据。这包括数据的获取、展示和更新等操作。 5. 性能优化:React项目中,性能优化是一个重要的职责。开发人员需要注意组件的渲染性能,避免不必要的渲染和重复计算。他们还可以使用React提供的性能工具(如React Profiler)来分析和优化应用的性能。 6. 测试和调试:开发人员需要编写单元测试和集成测试来确保React组件的正确性和稳定性。他们还需要使用浏览器开发工具(如Chrome DevTools)来调试和排查应用中的问题。 7. 项目构建和部署:React项目通常需要使用构建工具(如Webpack、Parcel等)将源代码打包成可部署的静态文件。开发人员需要配置构建工具,并将打包后的文件部署到服务器或云平台上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值