react antd 实现修改密码(原密码,新密码,再次输入新密码,新密码增加正则复杂度校验)

简介: 文章介绍了如何在React项目中使用Ant Design实现一个修改密码的组件,包括原密码、新密码和再次输入新密码的表单项,并为新密码增加了正则表达式复杂度校验。

先看样子

在这里插入图片描述
组件代码:

import React, {
    useState, useEffect } from 'react'
import {
    Row, Col, Modal, Spin, Input, Button, message, Form } from 'antd'
import {
    LockOutlined, EyeTwoTone, EyeInvisibleOutlined } from '@ant-design/icons'
import * as Serve from '@/serve/Serve/Serve'
// 添加弹窗
import {
    history } from 'umi'
export default function ({
    modalViPassword, onCancelPassword, firstLoginFlag = false }) {
   
    const [form] = Form.useForm()
    // 修改密码
    const [loadingPassword, setloadingPassword] = useState(false)
    const iconRender = visible => (visible ? <EyeTwoTone /> : <EyeInvisibleOutlined />)
    const modalCancelPassword = () => {
   
        form.resetFields()
        setloadingPassword(false)
    }
    const goLoginFun = () => {
   
        IPServe.systemlLogout()
        const href = '/AAAA/mainlogin'
        history.push({
   
            pathname: href,
        })
    }
    const onOkPassword = async () => {
   
        form.validateFields().then(async values => {
   
            let {
    oldPassword, newPassword,  } = form.getFieldsValue()

            modalCancelPassword()

        })
    }
    return (
        modalViPassword && (
            <Modal visible={
   modalViPassword} footer={
   null} destroyOnClose closable={
   false} width={
   600} title={
   '密码修改'} onCancel={
   modalCancelPassword}>
                <Spin spinning={
   loadingPassword}>
                    <Form initialValues={
   {
   }} labelCol={
   {
    span: 6 }} wrapperCol={
   {
    span: 18 }} form={
   form} autoComplete="off" colon={
   false}>
                        {
   !firstLoginFlag && (
                            <Row style={
   {
    width: '88%', margin: '0px auto 10px', display: 'flex', alignItems: 'center' }}>
                                <Col span={
   24}>
                                    <Form.Item
                                        name="oldPassword"
                                        label="原密码:"
                                        rules={
   [
                                            {
   
                                                required: true,
                                                message: '请输入原密码!',
                                            },
                                        ]}
                                    >
                                        <Input.Password
                                            size="large"
                                            placeholder="请输入原密码"
                                            prefix={
   <LockOutlined style={
   {
    color: '#ec5e59' }} />}
                                            iconRender={
   iconRender}
                                        />
                                    </Form.Item>
                                </Col>
                            </Row>
                        )}
                        <Row style={
   {
    width: '88%', margin: '0px auto 10px', display: 'flex', alignItems: 'center' }}>
                            <Col span={
   24}>
                                <Form.Item
                                    name="newPassword"
                                    label="新密码:"
                                    rules={
   [
                                        {
   
                                            required: true,
                                            message: '请输入新密码!',
                                        },
                                        {
   
                                            pattern: /(?=.*[0-9])(?=.*[A-Z])(?=.*[a-z])(?=.*[^a-zA-Z0-9]).{8,20}/,
                                            message: '请输入8-20位数的密码,其中包含大小写字母、数字和特殊符号四种'
                                        },
                                    ]}
                                >
                                    <Input.Password
                                        size="large"
                                        placeholder="请输入新密码"
                                        prefix={
   <LockOutlined style={
   {
    color: '#ec5e59' }} />}
                                        iconRender={
   iconRender}
                                    />
                                </Form.Item>
                            </Col>
                        </Row>
                        <Row style={
   {
    width: '88%', margin: '0px auto 10px', display: 'flex', alignItems: 'center' }}>
                            <Col span={
   24}>
                                <Form.Item
                                    name="newPassword2"
                                    label="复输新密码:"
                                    rules={
   [
                                        {
   
                                            required: true,
                                            message: '请再次输入新密码!',
                                        },
                                        {
   
                                            pattern: /(?=.*[0-9])(?=.*[A-Z])(?=.*[a-z])(?=.*[^a-zA-Z0-9]).{8,20}/,
                                            message: '请输入8-20位数的密码,其中包含大小写字母、数字和特殊符号四种'
                                        },
                                        ({
    getFieldValue }) => ({
   
                                            validator(_, value) {
   
                                                if (
                                                    !value ||
                                                    (getFieldValue('newPassword') && getFieldValue('newPassword').trim()) === (value && value.trim())
                                                ) {
   
                                                    return Promise.resolve()
                                                }
                                                return Promise.reject(new Error('两次新密码请保持一致!'))
                                            },
                                        }),
                                    ]}
                                >
                                    <Input.Password
                                        size="large"
                                        placeholder="请再次输入新密码"
                                        prefix={
   <LockOutlined style={
   {
    color: '#ec5e59' }} />}
                                        iconRender={
   iconRender}
                                    />
                                </Form.Item>
                            </Col>
                        </Row>
                    </Form>
                    <Row justify="end" style={
   {
    marginTop: '15px' }}>
                        <Button type="primary" style={
   {
    marginRight: '15px' }} onClick={
   onOkPassword}>
                            修改
                        </Button>
                        <Button type="ghost" style={
   {
    backgroundColor: '#fff' }} onClick={
   modalCancelPassword}>
                            取消
                        </Button>
                    </Row>
                </Spin>
            </Modal>
        )
    )
}
目录
相关文章
|
6月前
|
前端开发 JavaScript 测试技术
从零开始搭建react+typescript+antd+redux+less+vw自适应项目
从零开始搭建react+typescript+antd+redux+less+vw自适应项目
178 0
|
6月前
|
前端开发 JavaScript 数据安全/隐私保护
详解React antd中setFieldsValu的简便使用
详解React antd中setFieldsValu的简便使用
238 0
|
6月前
|
前端开发
React中Props的详细使用和props的校验
React中Props的详细使用和props的校验
|
2月前
|
前端开发 JavaScript 网络架构
react对antd中Select组件二次封装
本文介绍了如何在React中对Ant Design(antd)的Select组件进行二次封装,包括创建MSelect组件、定义默认属性、渲染Select组件,并展示了如何使用Less进行样式定义和如何在项目中使用封装后的Select组件。
89 2
react对antd中Select组件二次封装
|
2月前
|
前端开发
React给antd中TreeSelect组件左侧加自定义图标icon
本文介绍了如何在React中为Ant Design的TreeSelect组件的每个树节点添加自定义图标,并解决了因缺少key属性而导致的警告问题,展示了如何通过递归函数处理treeData数据并为每个节点添加图标。
103 2
React给antd中TreeSelect组件左侧加自定义图标icon
|
2月前
|
前端开发
react使用antd中的Checkbox实现多选
在React项目中,通过Ant Design的Checkbox组件实现多选。引入Checkbox,使用Checkbox.Group来管理Checkbox,设置`value`属性绑定选中项数组,通过`onChange`更新数组。维护一个全选状态,根据选中项数量与总数决定全选按钮状态。全选按钮的`onChange`事件用于控制所有Checkbox的选中状态。
80 1
react使用antd中的Checkbox实现多选
|
2月前
|
前端开发
React添加路径别名alias、接受props默认值、并二次封装antd中Modal组件与使用
本文介绍了在React项目中如何添加路径别名alias以简化模块引入路径,设置组件props的默认值,以及如何二次封装Ant Design的Modal组件。文章还提供了具体的代码示例,包括配置Webpack的alias、设置defaultProps以及封装Modal组件的步骤和方法。
66 1
React添加路径别名alias、接受props默认值、并二次封装antd中Modal组件与使用
|
2月前
|
前端开发 JavaScript 区块链
react18函数组件+antd使用指南-使用代码集合以及报错记录汇总
本文介绍了多个React开发中常见的问题及其解决方案,包括但不限于:1)`useForm`实例未连接到任何`Form`元素的警告及解决方法;2)监听页面滚动事件的实现方式;3)React 18与antd 5.8.6中定制主题的方法;4)React结合antd 4.x版本自定义主题色的步骤;5)解决`ResizeObserver loop`相关报错的技巧;6)处理React设计表单时遇到的CDN资源加载失败问题;7)解决onClick事件传参问题;8)修复类型错误等。每部分均提供详细分析与实用代码示例,帮助开发者快速定位并解决问题。
45 2
|
2月前
|
前端开发 JavaScript
React配合axios请求拦截校验session,403跳转至登陆页面
React中使用axios进行请求拦截,通过自定义事件监听和响应拦截实现403状态码时的自动登录页面跳转。
73 2
|
2月前
|
前端开发 计算机视觉
React使用antd实现可编辑单元格
React结合Ant Design实现可编辑单元格的表格组件,通过EditableRow和EditableCell封装实现单元格编辑功能,并提供saveFun回调保存编辑内容。
89 1