React - 实现一个基于 Antd 的密码强度校验组件

在基于 NestUmi 技术栈的个人项目开发中,在用户管理模块需要用到一个密码强度校验组件,在网上寻找一方资料,没有找到自己想要的,特此自己造轮子!

效果预览

在这里插入图片描述

组件思想

既然是密码强度校验,那么强度就必须有个梯度,这个时候就必须找到一个合适的效果,我们有两种方向:

  1. 组件库找个合适的 UI
  2. 自己开发造轮子

经过一番摸索,Antd-Process 组件进入了我的视野:
在这里插入图片描述

于是我决定基于这个组件改造一番!

组件开发

  1. 在目录 /src/components 新建 StrengthMeter/index.tsx 文件,开发基本结构。
/*
 @Description: 密码强度组件
 @Version: 2.0
 @Author: 白雾茫茫丶
 @Date: 2023-01-09 17:15:19
 @LastEditors: 白雾茫茫丶
 @LastEditTime: 2023-01-16 15:40:45
*/
import type { FC } from 'react'
import { Progress, Form, Row, Col } from 'antd';
import { ProFormText } from '@ant-design/pro-components'; // antd 高级组件
import zxcvbn from 'zxcvbn'; // 密码强度校验

const StrengthMeter: FC = () => {
  // 获取上下文 form 实例
  const form = Form.useFormInstance();
  // 监听密码的改变
  const password = Form.useWatch('password', form);

  /**
   * @description: 监听密码强度相应变化
   * @param {string} password
   */
  const watchStrength = (password: string): number => {
    const analysisValue = zxcvbn(password)
    // score得分只有0~4,且只有整数范围并没有小数
    return (analysisValue.score + 1) * 20
  }

  return (
    <>
      {/* 密码 */}
      <ProFormText.Password
        label="密码"
        name="password"
        rules={[{ required: true, min: 6, max: 12, message: "请输入密码" }]}
      />
      {/* 确认密码 */}
      <ProFormText.Password
        label="确认密码"
        name="confirmPassword"
        fieldProps={{ visibilityToggle: false }}
        rules={[
          { required: true, message: "请输入确认密码" },
          ({ getFieldValue }) => ({
            validator(_, value) {
              if (!value || getFieldValue('password') === value) {
                return Promise.resolve();
              }
              return Promise.reject(new Error("两次密码输入不一致"));
            },
          })
        ]}
      />
      {/* 显示密码强度 */}
      <Progress
        percent={password ? watchStrength(password) : 0}
        steps={5}
        strokeColor={['#e74242', '#EFBD47', '#ffa500', '#1bbf1b', '#008000']}
        showInfo={false}
      />
      <Row justify="space-around">
        {
          ['非常弱', '弱', '一般', '强', '非常强'].map(value => <Col span={4} key={value}>{value}  </Col>)
        }
      </Row>
    </>
  )
}

export default StrengthMeter
  1. 由于 Progressant-progress-steps-item 无法自动撑开,我们需要新建一个 index.module.less 文件做样式穿透:
.process-steps{
  width:100%;
  text-align: center;
  :global(.ant-progress){
    width:100%
  }
  :global(.ant-progress .ant-progress-steps-item){
    width:calc(20% - 2px) !important
  }
}
  1. 引入样式并绑定类名:
import styles from './index.module.less'

<div className={styles['process-steps']}>
    <Progress
      percent={password ? watchStrength(password) : 0}
      steps={5}
      strokeColor={['#e74242', '#EFBD47', '#ffa500', '#1bbf1b', '#008000']}
      showInfo={false}
    />
</div>
<Row justify="space-around" className={styles['process-steps']}>
    {
      ['非常弱', '弱', '一般', '强', '非常强'].map(value => <Col span={4} key={value}>{value}</Col>)
    }
</Row>

这时候就能得到我们想要的效果了,接下来我们要校验密码强度。

安装 zxcvbn

  • 执行安装命令
pnpm add zxcvbn
  • 页面引入
import zxcvbn from 'zxcvbn';

// zxcvbn 是个函数,接收一个参数,参数就是字符串密码。
zxcvbn("abc123456");

该函数返回一个对象,其中与密码强度相关的属性有:guessesguesses_log10score
在这里插入图片描述

那么这三个属性,我们应该怎么选择呢?

  • guesses 值很大,不利于我们判断。
  • guesses_log10 的值越大越安全,根据测试,值在 12 以上就很安全了。
  • score 的取值范围只有整数 0~4,值越大越安全。
  • 如果业务考虑的场景比较多,建议使用 guesses_log10,这里我们封装使用 score
  1. 使用 Form.useWatch 监听 password 的变化:
// 获取上下文 form 实例
const form = Form.useFormInstance();
// 监听密码的改变
const password = Form.useWatch('password', form);

编写一个函数解析 password

const watchStrength = (password: string): number => {
    const analysisValue = zxcvbn(password)
    // score得分只有0~4,且只有整数范围并没有小数
    return (analysisValue.score + 1) * 20
}
  1. 绑定到 Progress 组件:
<Progress
  percent={password ? watchStrength(password) : 0}
  steps={5}
  strokeColor={['#e74242', '#EFBD47', '#ffa500', '#1bbf1b', '#008000']}
  showInfo={false}
/>

到这里,我们的任务就完成了,我们一起看看实际效果吧:
在这里插入图片描述

仓库地址:Xmw-Admin

如果对你有用,麻烦给个 Star !

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
当使用React Hooks和Antd的Form组件进行表单校,并且配合React-Draft-Wysig富文本框时,输入内容提示立即消失的问题可以通过以下方式解决: 首先,确已经安装了相关的依赖包: ` npm install antd react-draft-wysiwy draft-js ``` 然后,创建一个新的组件,命名为DemoForm: ``` import React, { useState } from ''; import { Form, Input, Button } fromantd'; import { EditorState, ContentState from 'draft-js'; import { } from 'react-draft-wysiwyg'; import 'react-draft-wysiwyg/dist/react-draft-wysiwyg.css'; const DemoForm = () => { const [editorState, setEditorState] = useState(EditorState.createEmpty()); const [form] = Form.useForm(); const handleFormSubmit = (values) => { console.log(values); }; const handleEditorChange = (state) => { setEditorState(state); }; return ( <Form form={form} onFinish={handleFormSubmit}> <Form.Item name="content" rules={[ { required: true, message: '请输入内容', }, ]} > <Editor editorState={editorState} onEditorStateChange={handleEditorChange} /> </Form.Item> <Form.Item> <Button type="primary" htmlType="submit"> 提交 </Button> </Form.Item> </Form> ); }; export default DemoForm; ``` 在上面的代码中,我们使用useState钩子来管理富文本框的编辑状态(editorState)和Form组件的表单状态(form)。onEditorStateChange函数用于更新编辑状态,handleFormSubmit函数用于处理表单提交。 在Form.Item组件中,我们使用了rules属性来进行表单校验。在这个例子中,我们要求content字段是必填的,如果没有输入内容,会显示"请输入内容"的错误提示。 最后,通过使用Editor组件来展示富文本框,并且将editorState和handleEditorChange函数传递给它。 这样,在输入内容时,如果没有满足校验规则,会显示错误提示,直到满足规则或者手动清空输入内容。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

白雾茫茫丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值