前端实现输入内容计算密码强度

本文介绍了如何在前端实现密码强度计算和动画展示。通过监听密码输入框的变化,使用@zxcvbn-ts/core库计算密码强度分数,然后根据分数调整动画的进度和颜色,以直观展示密码强度。文章提供了完整的代码示例。
摘要由CSDN通过智能技术生成

提示:记录工作中遇到的需求及解决办法


前言

平时我们在浏览各种网站和 APP 的时候,都接触过密码这个东西~

密码设置的好不好,关乎到你的账号安全性,越复杂的密码越安全,所以密码强度很重要,而我们在做注册功能的时候,也有责任去帮协助用户设置一个高密码强度的密码~

那么密码强度怎么计算呢? 且应该如何实现以下这样的密码强度动画展示效果呢?

在这里插入图片描述


一、思路

其实思路很简单:

  1. 监听密码输入框的变化
  2. 密码变化时,获取密码文本,并通过某种方式计算这个密码的强度分数
  3. 根据强度分数,改变下方块的颜色和宽度
    0分:强度低,红色,宽度 20%
    2) 1分:强度低,红色,宽度 40%
    3) 2分:强度中,橙色,宽度 60%
    4) 3分:强度高,绿色,宽度 80%
    5) 4分:强度高,绿色,宽度 100%
    在这里插入图片描述

二、计算密码强度分数

用什么方式去计算密码强度方式呢?我们可以用 @zxcvbn-ts/core这个库来计算~

@zxcvbn-ts/core 是 zxcvbn 密码强度估计器的 TypeScript 实现版本,用于帮助开发者评估用户设置密码的复杂度和安全性,计算的依据有:

  1. 密码长度: 越长分数越高
  2. 字符类型: 数字、字母、符号
  3. 词典攻击检测: 内置词典列表,检测密码强度
  4. 评分系统: 0-4分,分数越高越安全
  5. 熵计算: 评测密码所需尝试次数,熵越高,分数越高
pnpm i @zxcvbn-ts/core

在这里插入图片描述

密码强度动画展示效果

计算了分数之后,我们需要根据分数去展示

1. 不同的颜色
2. 不同的宽度

我们可以使用属性选择器的方式,去完成这一个效果,看以下代码~

在这里插入图片描述

当密码改变的时候,会实时计算密码强度分数,这也就是意味着 data-score 这个属性会一直变,接着我们可以在样式中,去根据属性选择器去设置不同的颜色和宽度

在这里插入图片描述

现在可以看到这样的效果

在这里插入图片描述

完善动画效果

在这里插入图片描述

现在可以达到我们期望的效果~

在这里插入图片描述

完整代码

<template>
  <Input.Password v-model:value="password" autocomplete="none" />
  <div class=
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

阿超学编程

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

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

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

打赏作者

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

抵扣说明:

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

余额充值