vue+element-ui集成随机验证码+用户名+密码的form表单验证功能


Posted in Javascript onAugust 05, 2018

 在登入页面,我们往往需要通过输入验证码才能进行登入,那我们下面就详讲一下在vue项目中如何配合element-ui实现这个功能

第一步:自定义一个生产随机验证码的组件,其本质是使用canvas绘制,详细代码如下:

<template>
 <div class="s-canvas">
 <canvas id="s-canvas" :width="contentWidth" :height="contentHeight"></canvas>
 </div>
</template>
<script>
export default {
 name: 'SIdentify',
 props: {
 identifyCode: {
  type: String,
  default: '1234'
 },
 fontSizeMin: {
  type: Number,
  default: 16
 },
 fontSizeMax: {
  type: Number,
  default: 40
 },
 backgroundColorMin: {
  type: Number,
  default: 180
 },
 backgroundColorMax: {
  type: Number,
  default: 240
 },
 colorMin: {
  type: Number,
  default: 50
 },
 colorMax: {
  type: Number,
  default: 160
 },
 lineColorMin: {
  type: Number,
  default: 40
 },
 lineColorMax: {
  type: Number,
  default: 180
 },
 dotColorMin: {
  type: Number,
  default: 0
 },
 dotColorMax: {
  type: Number,
  default: 255
 },
 contentWidth: {
  type: Number,
  default: 112
 },
 contentHeight: {
  type: Number,
  default: 38
 }
 },
 methods: {
 // 生成一个随机数
 randomNum(min, max) {
  return Math.floor(Math.random() * (max - min) + min)
 },
 // 生成一个随机的颜色
 randomColor(min, max) {
  var r = this.randomNum(min, max)
  var g = this.randomNum(min, max)
  var b = this.randomNum(min, max)
  return 'rgb(' + r + ',' + g + ',' + b + ')'
 },
 drawPic() {
  var canvas = document.getElementById('s-canvas')
  var ctx = canvas.getContext('2d')
  ctx.textBaseline = 'bottom'
  // 绘制背景
  ctx.fillStyle = this.randomColor(
  this.backgroundColorMin,
  this.backgroundColorMax
  )
  ctx.fillRect(0, 0, this.contentWidth, this.contentHeight)
  // 绘制文字
  for (let i = 0; i < this.identifyCode.length; i++) {
  this.drawText(ctx, this.identifyCode[i], i)
  }
  this.drawLine(ctx)
  this.drawDot(ctx)
 },
 drawText(ctx, txt, i) {
  ctx.fillStyle = this.randomColor(this.colorMin, this.colorMax)
  ctx.font =
  this.randomNum(this.fontSizeMin, this.fontSizeMax) + 'px SimHei'
  var x = (i + 1) * (this.contentWidth / (this.identifyCode.length + 1))
  var y = this.randomNum(this.fontSizeMax, this.contentHeight - 5)
  var deg = this.randomNum(-45, 45)
  // 修改坐标原点和旋转角度
  ctx.translate(x, y)
  ctx.rotate(deg * Math.PI / 180)
  ctx.fillText(txt, 0, 0)
  // 恢复坐标原点和旋转角度
  ctx.rotate(-deg * Math.PI / 180)
  ctx.translate(-x, -y)
 },
 drawLine(ctx) {
  // 绘制干扰线
  for (let i = 0; i < 8; i++) {
  ctx.strokeStyle = this.randomColor(
   this.lineColorMin,
   this.lineColorMax
  )
  ctx.beginPath()
  ctx.moveTo(
   this.randomNum(0, this.contentWidth),
   this.randomNum(0, this.contentHeight)
  )
  ctx.lineTo(
   this.randomNum(0, this.contentWidth),
   this.randomNum(0, this.contentHeight)
  )
  ctx.stroke()
  }
 },
 drawDot(ctx) {
  // 绘制干扰点
  for (let i = 0; i < 100; i++) {
  ctx.fillStyle = this.randomColor(0, 255)
  ctx.beginPath()
  ctx.arc(
   this.randomNum(0, this.contentWidth),
   this.randomNum(0, this.contentHeight),
   1,
   0,
   2 * Math.PI
  )
  ctx.fill()
  }
 }
 },
 watch: {
 identifyCode() {
  this.drawPic()
 }
 },
 mounted() {
 this.drawPic()
 }
}
</script>

第二步:使用该组件:

我们首先新建一个vue组件,在该组件进行布局,其中还包括用户名和密码的验证(这只是前端的简单验证,真实项目中还需要请求登入接口进行后端验证)

<template>
 <el-form class="login-form" status-icon :rules="loginRules" ref="loginForm" :model="loginForm" label-width="0">
 <el-form-item prop="username">
  <el-input size="small" @keyup.enter.native="handleLogin" v-model="loginForm.username" auto-complete="off" placeholder="请输入用户名">
  <i slot="prefix" class="icon-yonghu"></i>
  </el-input>
 </el-form-item>
 <el-form-item prop="password">
  <el-input size="small" @keyup.enter.native="handleLogin" :type="passwordType" v-model="loginForm.password" auto-complete="off" placeholder="请输入密码">
  <i class="el-icon-view el-input__icon" :style="fontstyle" slot="suffix" @click="showPassword"></i>
  <i slot="prefix" class="icon-mima"></i>
  </el-input>
 </el-form-item>
 <el-form-item prop="verifycode">
  <!-- 注意:prop与input绑定的值一定要一致,否则验证规则中的value会报undefined,因为value即为绑定的input输入值 -->
  <el-input v-model="loginForm.verifycode" placeholder="请输入验证码" class="identifyinput"></el-input>
 </el-form-item>
 <el-form-item>
  <div class="identifybox">
  <div @click="refreshCode">
   <s-identify :identifyCode="identifyCode"></s-identify>
  </div>
  <el-button @click="refreshCode" type='text' class="textbtn">看不清,换一张</el-button>
  </div>
 </el-form-item>
 <el-checkbox v-model="checked">记住账号</el-checkbox>
 <el-form-item>
  <el-button type="primary" size="small" @click.native.prevent="handleLogin" class="login-submit">登录</el-button>
 </el-form-item>
 </el-form>
</template>

 第三步:生产随机码与进行登入验证

<script>
import { isvalidUsername } from '@/utils/validate'
import SIdentify from '@/components/identify/identify.vue'
export default {
 name: 'userlogin',
 data() {
 // 用户名自定义验证规则
 const validateUsername = (rule, value, callback) => {
  if (!isvalidUsername(value)) {
  callback(new Error('请输入正确的用户名'))
  } else {
  console.log('user', value)
  callback()
  }
 }
 // 验证码自定义验证规则
 const validateVerifycode = (rule, value, callback) => {
  if (value === '') {
  callback(new Error('请输入验证码'))
  } else if (value !== this.identifyCode) {
  console.log('validateVerifycode:', value)
  callback(new Error('验证码不正确!'))
  } else {
  callback()
  }
 }
 return {
  fontstyle: {
  },
  loginForm: {
  username: 'admin',
  password: '123456',
  verifycode: ''
  },
  checked: false,
  identifyCodes: '1234567890',
  identifyCode: '',
  loginRules: { // 绑定在form表单中的验证规则
  username: [
   { required: true, trigger: 'blur', validator: validateUsername }
  ],
  password: [
   { required: true, message: '请输入密码', trigger: 'blur' },
   { min: 6, message: '密码长度最少为6位', trigger: 'blur' }
  ],
  verifycode: [
   { required: true, trigger: 'blur', validator: validateVerifycode }
  ]
  },
  passwordType: 'password'
 }
 },
 components: {
 SIdentify
 },
 created() {
 },
 mounted() {
 // 验证码初始化
 this.identifyCode = ''
 this.makeCode(this.identifyCodes, 4)
 },
 computed: {
 },
 props: [],
 methods: {
 // 通过改变input的type使密码可见
 showPassword() {
  this.fontstyle === '' ? (this.fontstyle = 'color: red') : (this.fontstyle = '') // 改变密码可见按钮颜色
  this.passwordType === ''
  ? (this.passwordType = 'password')
  : (this.passwordType = '')
 },
 // 点击登入按钮
 handleLogin() {
  this.$refs.loginForm.validate(valid => {
  if (valid) {
   this.$store.dispatch('Login', this.loginForm).then(res => {
   this.$router.push({ path: '/dashboard/dashboard' })
   })
  }
  })
 },
 // 生成随机数
 randomNum(min, max) {
  return Math.floor(Math.random() * (max - min) + min)
 },
 // 切换验证码
 refreshCode() {
  this.identifyCode = ''
  this.makeCode(this.identifyCodes, 4)
 },
 // 生成四位随机验证码
 makeCode(o, l) {
  for (let i = 0; i < l; i++) {
  this.identifyCode += this.identifyCodes[
   this.randomNum(0, this.identifyCodes.length)
  ]
  }
  console.log(this.identifyCode)
 }
 }
}
</script>
<style scoped>
.identifybox{
 display: flex;
 justify-content: space-between;
 margin-top:7px;
}
.iconstyle{
 color:#409EFF;
}
</style>

最后的效果如下,当我们输入之后鼠标失去焦点就会进行验证:

vue+element-ui集成随机验证码+用户名+密码的form表单验证功能

总结

以上所述是小编给大家介绍的vue+element-ui集成随机验证码+用户名+密码的form表单验证功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
javascript document.referrer 用法
Apr 30 Javascript
Jquery知识点三 jquery表单对象操作
Jan 17 Javascript
使用Jquery Aajx访问WCF服务(GET、POST、PUT、DELETE)
Mar 16 Javascript
js修改table中Td的值(定义td的双击事件)
Jan 10 Javascript
javascript使用百度地图api和html5特性获取浏览器位置
Jan 10 Javascript
JavaScript原生对象之Date对象的属性和方法详解
Mar 13 Javascript
理解javascript正则表达式
Mar 08 Javascript
jQuery事件绑定on()与弹窗实现代码
Apr 28 Javascript
vue不通过路由直接获取url中参数的方法示例
Aug 24 Javascript
angular中ui calendar的一些使用心得(推荐)
Nov 03 Javascript
Vue基于localStorage存储信息代码实例
Nov 16 Javascript
JS数组去重详情
Nov 07 Javascript
dts文件中删除一个node或属性的操作方法
Aug 05 #Javascript
深入理解JavaScript的async/await
Aug 05 #Javascript
js数据类型检测总结
Aug 05 #Javascript
通过函数作用域和块级作用域看javascript的作用域链
Aug 05 #Javascript
vue实现简单的MVVM框架
Aug 05 #Javascript
使用D3.js+Vue实现一个简单的柱形图
Aug 05 #Javascript
详解Require.js与Sea.js的区别
Aug 05 #Javascript
You might like
用session做客户验证时的注意事项
2006/10/09 PHP
在wamp集成环境下升级php版本(实现方法)
2013/07/01 PHP
PHP异常处理Exception类
2015/12/11 PHP
Symfony2实现在controller中获取url的方法
2016/03/18 PHP
微信公众号判断用户是否已关注php代码解析
2016/06/24 PHP
PHP _construct()函数讲解
2019/02/03 PHP
JavaScript 动态改变图片大小
2009/06/11 Javascript
JQuery下关于$.Ready()的分析
2009/12/13 Javascript
仅IE6/7/8中innerHTML返回值忽略英文空格的问题
2011/04/07 Javascript
jQuery提交多个表单的小例子
2013/06/30 Javascript
原生javascript实现addClass,removeClass,hasClass函数
2016/02/25 Javascript
Javascript中获取浏览器类型和操作系统版本等客户端信息常用代码
2016/06/28 Javascript
JavaScript设计模式之单体模式全面解析
2016/09/09 Javascript
BootStrap框架个人总结(bootstrap框架、导航条、下拉菜单、轮播广告carousel、栅格系统布局、标签页tabs、模态框、菜单定位)
2016/12/01 Javascript
JavaScript使用链式方法封装jQuery中CSS()方法示例
2017/04/07 jQuery
基于JavaScript实现的希尔排序算法分析
2017/04/14 Javascript
JQuery通过后台获取数据遍历到前台的方法
2018/08/13 jQuery
基于vue-cli 路由 实现类似tab切换效果(vue 2.0)
2019/05/08 Javascript
防止Layui form表单重复提交的实现方法
2019/09/10 Javascript
高效jQuery选择器的5个技巧实例分析
2019/11/26 jQuery
vue框架中props的typescript用法详解
2020/02/17 Javascript
js实现浏览器打印功能的示例代码
2020/07/15 Javascript
Python的Urllib库的基本使用教程
2015/04/30 Python
Python3.9又更新了:dict内置新功能
2020/02/28 Python
PyTorch中torch.tensor与torch.Tensor的区别详解
2020/05/18 Python
python如何查看安装了的模块
2020/06/23 Python
匡威荷兰官方网站:Converse荷兰
2018/10/24 全球购物
领先的英国注册在线药房 :Simply Meds Online
2019/03/28 全球购物
正宗的日本零食和糖果订阅盒:Bokksu
2019/11/21 全球购物
信用社实习人员自我鉴定
2013/09/20 职场文书
怎么写好自荐书
2014/03/02 职场文书
派出所副所长四风问题个人整改措施思想汇报
2014/10/13 职场文书
Python 解决空列表.append() 输出为None的问题
2021/05/23 Python
DBCA命令行搭建Oracle ADG的流程
2021/06/11 Oracle
MySQL数据库索引的最左匹配原则
2021/11/20 MySQL
Java 定时任务技术趋势简介
2022/05/04 Java/Android