热门标签 | 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


推荐阅读
  • 在 Vue 应用开发中,页面状态管理和跨页面数据传递是常见需求。本文将详细介绍 Vue Router 提供的两种有效方式,帮助开发者高效地实现页面间的数据交互与状态同步,同时分享一些最佳实践和注意事项。 ... [详细]
  • WinMain 函数详解及示例
    本文详细介绍了 WinMain 函数的参数及其用途,并提供了一个具体的示例代码来解析 WinMain 函数的实现。 ... [详细]
  • 微信公众号推送模板40036问题
    返回码错误码描述说明40001invalidcredential不合法的调用凭证40002invalidgrant_type不合法的grant_type40003invalidop ... [详细]
  • Framework7:构建跨平台移动应用的高效框架
    Framework7 是一个开源免费的框架,适用于开发混合移动应用(原生与HTML混合)或iOS&Android风格的Web应用。此外,它还可以作为原型开发工具,帮助开发者快速创建应用原型。 ... [详细]
  • poj 3352 Road Construction ... [详细]
  • 为了确保iOS应用能够安全地访问网站数据,本文介绍了如何在Nginx服务器上轻松配置CertBot以实现SSL证书的自动化管理。通过这一过程,可以确保应用始终使用HTTPS协议,从而提升数据传输的安全性和可靠性。文章详细阐述了配置步骤和常见问题的解决方法,帮助读者快速上手并成功部署SSL证书。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 本文介绍了如何利用ObjectMapper实现JSON与JavaBean之间的高效转换。ObjectMapper是Jackson库的核心组件,能够便捷地将Java对象序列化为JSON格式,并支持从JSON、XML以及文件等多种数据源反序列化为Java对象。此外,还探讨了在实际应用中如何优化转换性能,以提升系统整体效率。 ... [详细]
  • 在处理木偶评估函数时,我发现可以顺利传递本机对象(如字符串、列表和数字),但每当尝试将JSHandle或ElementHandle作为参数传递时,函数会拒绝接受这些对象。这可能是由于这些句柄对象的特殊性质导致的,建议在使用时进行适当的转换或封装,以确保函数能够正确处理。 ... [详细]
  • Vue ElementUI 实现邮箱地址自动补全功能详解 ... [详细]
  • 尽管我们尽最大努力,任何软件开发过程中都难免会出现缺陷。为了更有效地提升对支持部门的协助与支撑,本文探讨了多种策略和最佳实践,旨在通过改进沟通、增强培训和支持流程来减少这些缺陷的影响,并提高整体服务质量和客户满意度。 ... [详细]
  • Mr.J 的 jQuery 学习笔记:第三十一讲——深入解析事件操作(on/off)方法
    `on()` 方法用于在选定元素及其子元素上绑定一个或多个事件处理程序。从 jQuery 1.7 版本开始,`on()` 方法取代了 `bind()`、`delegate()` 和 `live()` 方法,成为统一的事件绑定方式。该方法不仅支持直接绑定事件,还支持事件委托,使得事件处理更加灵活和高效。通过 `off()` 方法,可以移除之前使用 `on()` 绑定的事件处理程序,从而实现对事件的动态管理。 ... [详细]
  • 深入解析:React与Webpack配置进阶指南(第二部分)
    在本篇进阶指南的第二部分中,我们将继续探讨 React 与 Webpack 的高级配置技巧。通过实际案例,我们将展示如何使用 React 和 Webpack 构建一个简单的 Todo 应用程序,具体包括 `TodoApp.js` 文件中的代码实现,如导入 React 和自定义组件 `TodoList`。此外,我们还将深入讲解 Webpack 配置文件的优化方法,以提升开发效率和应用性能。 ... [详细]
  • 在Delphi7下要制作系统托盘,只能制作一个比较简单的系统托盘,因为ShellAPI文件定义的TNotifyIconData结构体是比较早的版本。定义如下:1234 ... [详细]
  • 本文详细介绍了如何安全地手动卸载Exchange Server 2003,以确保系统的稳定性和数据的完整性。根据微软官方支持文档(https://support.microsoft.com/kb833396/zh-cn),在进行卸载操作前,需要特别注意备份重要数据,并遵循一系列严格的步骤,以避免对现有网络环境造成不利影响。此外,文章还提供了详细的故障排除指南,帮助管理员在遇到问题时能够迅速解决,确保整个卸载过程顺利进行。 ... [详细]
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社区 版权所有