热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

React+Redux+AntDesign+TypeScript电子商务实战客户端应用06普通用户dashboard页面

普通用户Dashboard页面src\components\admin\Dashboard.tsximport{Col,Descriptions,List,Menu,messa
普通用户 Dashboard 页面

// src\components\admin\Dashboard.tsx
import { Col, Descriptions, List, Menu, message, Row, Typography } from 'antd'
import { Link } from 'react-router-dom'
import Layout from '../core/Layout'
import { ShoppingCartOutlined, UserOutlined } from '@ant-design/icons'
import { isAuth } from '../../helpers/auth'
import { Jwt } from '../../store/models/auth'
import { useEffect, useState } from 'react'
import axios from 'axios'
import { API } from '../../config'
import { Order, OrderProduct } from &#39;../../store/models/order&#39;const { Title } &#61; Typographyconst Dashboard &#61; () &#61;> {const {token,user: { name, email, _id: userId }} &#61; isAuth() as Jwtconst links &#61; () &#61;> (<><Title level&#61;{5}>用户导航</Title><Menu style&#61;{{ borderRight: 0 }}><Menu.Item><ShoppingCartOutlined style&#61;{{ marginRight: &#39;5px&#39; }} /><Link to&#61;"/cart">购物车</Link></Menu.Item><Menu.Item><UserOutlined style&#61;{{ marginRight: &#39;5px&#39; }} /><Link to&#61;"/user/profile">资料更新</Link></Menu.Item></Menu></>)const info &#61; () &#61;> (<Descriptions title&#61;"用户信息" bordered><Descriptions.Item label&#61;"昵称">{name}</Descriptions.Item><Descriptions.Item label&#61;"邮箱">{email}</Descriptions.Item><Descriptions.Item label&#61;"角色">普通用户</Descriptions.Item></Descriptions>)const [orders, setOrders] &#61; useState([])async function getOrders() {try {const response &#61; await axios.get(&#96;${API}/user/orders/${userId}&#96;, {headers: {Authorization: &#96;Bearer ${token}&#96;}})setOrders(response.data)} catch (error) {message.error(error.response.data.errors[0])}}useEffect(() &#61;> {getOrders()}, [])const historyOrder &#61; () &#61;> (<><Title level&#61;{5} style&#61;{{ marginTop: &#39;20px&#39; }}>购买历史</Title><ListdataSource&#61;{orders}renderItem&#61;{(item: Order) &#61;> (<List.Item><Col span&#61;"18">{item.products.map(({ snapshot }: OrderProduct) &#61;> snapshot.name).join(&#39;、&#39;)}</Col><Col span&#61;"6">{item.amount}</Col></List.Item>)}/></>)return (<Layout title&#61;"用户 dashboard" subTitle&#61;""><Row><Col span&#61;"4">{links()}</Col><Col span&#61;"20">{info()}{historyOrder()}</Col></Row></Layout>)
}export default Dashboard

资料更新页面

页面布局

// src\components\admin\Profile.tsx
import { Button, Form, Input } from &#39;antd&#39;
import Layout from &#39;../core/Layout&#39;const Profile &#61; () &#61;> {return (<Layout title&#61;"资料更新" subTitle&#61;""><Form><Form.Item name&#61;"email" label&#61;"邮箱"><Input disabled /></Form.Item><Form.Item name&#61;"name" label&#61;"昵称"><Input /></Form.Item><Form.Item name&#61;"password" label&#61;"密码"><Input.Password /></Form.Item><Form.Item><Button type&#61;"primary" htmlType&#61;"submit">修改</Button></Form.Item></Form></Layout>)
}export default Profile

路由配置

// src\Routes.tsx
import Profile from &#39;./components/admin/Profile&#39;<PrivateRoute path&#61;"/user/profile" component&#61;{Profile} />

修改方法

// src\helpers\auth.ts
import { message } from &#39;antd&#39;
import axios from &#39;axios&#39;
import { API } from &#39;../config&#39;
import { SignupPayload } from &#39;../store/actions/auth.action&#39;
import { Jwt } from &#39;../store/models/auth&#39;// 是否登录
export function isAuth(): boolean | Jwt {const jwt &#61; localStorage.getItem(&#39;jwt&#39;)if (jwt) {return JSON.parse(jwt)}return false
}// 修改
export function update(value: SignupPayload) {const auth &#61; isAuth() as Jwtaxios.put(&#96;${API}/user/${auth.user._id}&#96;, value, {headers: {Authorization: &#96;Bearer ${auth.token}&#96;}}).then(({ data }) &#61;> {auth.user.email &#61; data.emailauth.user.name &#61; data.namelocalStorage.setItem(&#39;jwt&#39;, JSON.stringify(auth))message.success(&#39;修改成功&#39;)}).catch(error &#61;> {message.error(error.response.data.errors[0])})
}

修改操作

// src\components\admin\Profile.tsx
import { Button, Form, Input } from &#39;antd&#39;
import { isAuth, update } from &#39;../../helpers/auth&#39;
import { SignupPayload } from &#39;../../store/actions/auth.action&#39;
import { Jwt } from &#39;../../store/models/auth&#39;
import Layout from &#39;../core/Layout&#39;const Profile &#61; () &#61;> {const {user: { name, email }} &#61; isAuth() as Jwtconst onFinish &#61; (value: SignupPayload) &#61;> {update(value)}return (<Layout title&#61;"资料更新" subTitle&#61;""><Form onFinish&#61;{onFinish} initialValues&#61;{{ name, email }}><Form.Item name&#61;"email" label&#61;"邮箱"><Input disabled /></Form.Item><Form.Item name&#61;"name" label&#61;"昵称"><Input /></Form.Item><Form.Item name&#61;"password" label&#61;"密码"><Input.Password /></Form.Item><Form.Item><Button type&#61;"primary" htmlType&#61;"submit">修改</Button></Form.Item></Form></Layout>)
}export default Profile


推荐阅读
  • web.py开发web 第八章 Formalchemy 服务端验证方法
    本文介绍了在web.py开发中使用Formalchemy进行服务端表单数据验证的方法。以User表单为例,详细说明了对各字段的验证要求,包括必填、长度限制、唯一性等。同时介绍了如何自定义验证方法来实现验证唯一性和两个密码是否相等的功能。该文提供了相关代码示例。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • Gitlab接入公司内部单点登录的安装和配置教程
    本文介绍了如何将公司内部的Gitlab系统接入单点登录服务,并提供了安装和配置的详细教程。通过使用oauth2协议,将原有的各子系统的独立登录统一迁移至单点登录。文章包括Gitlab的安装环境、版本号、编辑配置文件的步骤,并解决了在迁移过程中可能遇到的问题。 ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了在rhel5.5操作系统下搭建网关+LAMP+postfix+dhcp的步骤和配置方法。通过配置dhcp自动分配ip、实现外网访问公司网站、内网收发邮件、内网上网以及SNAT转换等功能。详细介绍了安装dhcp和配置相关文件的步骤,并提供了相关的命令和配置示例。 ... [详细]
  • 展开全部下面的代码是创建一个立方体Thisexamplescreatesanddisplaysasimplebox.#Thefirstlineloadstheinit_disp ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 本文介绍了机器学习手册中关于日期和时区操作的重要性以及其在实际应用中的作用。文章以一个故事为背景,描述了学童们面对老先生的教导时的反应,以及上官如在这个过程中的表现。同时,文章也提到了顾慎为对上官如的恨意以及他们之间的矛盾源于早年的结局。最后,文章强调了日期和时区操作在机器学习中的重要性,并指出了其在实际应用中的作用和意义。 ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
  • Java自带的观察者模式及实现方法详解
    本文介绍了Java自带的观察者模式,包括Observer和Observable对象的定义和使用方法。通过添加观察者和设置内部标志位,当被观察者中的事件发生变化时,通知观察者对象并执行相应的操作。实现观察者模式非常简单,只需继承Observable类和实现Observer接口即可。详情请参考Java官方api文档。 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • 先看看ElementUI里关于el-table的template数据结构:<template><el-table:datatableData><e ... [详细]
  • React基础篇一 - JSX语法扩展与使用
    本文介绍了React基础篇一中的JSX语法扩展与使用。JSX是一种JavaScript的语法扩展,用于描述React中的用户界面。文章详细介绍了在JSX中使用表达式的方法,并给出了一个示例代码。最后,提到了JSX在编译后会被转化为普通的JavaScript对象。 ... [详细]
  • 本文介绍了使用Spark实现低配版高斯朴素贝叶斯模型的原因和原理。随着数据量的增大,单机上运行高斯朴素贝叶斯模型会变得很慢,因此考虑使用Spark来加速运行。然而,Spark的MLlib并没有实现高斯朴素贝叶斯模型,因此需要自己动手实现。文章还介绍了朴素贝叶斯的原理和公式,并对具有多个特征和类别的模型进行了讨论。最后,作者总结了实现低配版高斯朴素贝叶斯模型的步骤。 ... [详细]
  • 本文介绍了2015年九月八日的js学习总结及相关知识点,包括参考书《javaScript Dom编程的艺术》、js简史、Dom、DHTML、解释型程序设计和编译型程序设计等内容。同时还提到了最佳实践是将标签放到HTML文档的最后,并且对语句和注释的使用进行了说明。 ... [详细]
author-avatar
捕鱼达人2602929461
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有