作者:高小原gy_941 | 来源:互联网 | 2022-10-12 03:06
最近在自己写页面,模仿思否论坛,然后写登录注册UI的时候需要一个验证码组件. 去搜一下没找到什么合适的,而且大多都是基于后端的,于是自己手写一个。
演示
分析验证码组件
分析验证码功能
- 随机出现的数字大小写字母 (基础功能)
- 不同的数字或者字母有不同的颜色 (功能优化)
- 不同的数字或者字母有不同的字体大写 (功能优化)
- 不同的数字或者字母有不同的边距 (功能优化)
- 不同的数字或者字母有不同的倾斜角度 (功能优化)
- 更多功能优化...
分析组件功能
- 可以设置生成验证码的长度 (基本功能)
- 可以设置验证码组件的宽高 (基本功能)
编写验证码组件
template
最外层div绑定点击事件,点击后刷新验证码。
span是单个验证码的载体,样式动态绑定
methods
refreshCode 刷新验证码的方法
createdCode 生成验证码的方法
getStyle 为每个元素生成动态的样式
methods: {
refreshCode () {
this.createdCode()
},
createdCode () {
let len = this.length,
codeList = [],
chars = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz0123456789',
charsLen = chars.length
// 生成
for (let i = 0; i item.code).join(''))
},
// 动态绑定样式
getStyle (data) {
return `color: ${data.color}; font-size: ${data.fontSize}; padding: ${data.padding}; transform: ${data.transform}`
}
}
完整代码
使用
组件
源码地址
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。