2021-07-10

Vue 两个字段联合校验典型例子--修改密码

本文以校验两次密码的一致性应用,给出两个可变属性值的字段之间的联合校验的典型解决方案。

1、前言

  本文是前文《Vue Element-ui表单校验规则,你掌握了哪些?》针对多字段联合校验的典型应用。

  在修改密码时,一般需要确认两次密码一致,涉及2个属性字段。类似的涉及2个属性字段的情况有:

  • 日期时间范围,如果两者都有值,则要求:结束时间>=开始时间。
  • 数量关系:数量下限<=数量上限。

  特点是两个属性值都是可变的。本文以校验两次密码的一致性应用,给出两个可变属性值的字段之间的联合校验的典型解决方案。

2、方案实现

2.1、实现代码

  先给出表单的代码:

<template> <div id="contentwrapper"> <h5 align=left>用户管理 / 修改密码</h5> <!-- 分隔线 --> <el-divider></el-divider>  <el-form ref="form" :model="form" :rules="rules" label-width="100px">  <el-form-item label="原 密 码:" prop="oldPasswd">  <el-input v-model="form.oldPasswd" :type="password">   <!-- input中加图标必须要有slot="suffix"属性,不然无法显示图标 -->   <i slot="suffix" : @click="showPassword"></i>  </el-input>  </el-form-item>   <el-form-item label="新 密 码:" prop="newPasswd">  <el-input v-model="form.newPasswd" :type="password">   <i slot="suffix" : @click="showPassword"></i>  </el-input>  </el-form-item>   <el-form-item label="确认密码:" prop="confirmPasswd">  <el-input v-model="form.confirmPasswd" :type="password">   <i slot="suffix" : @click="showPassword"></i>  </el-input>  </el-form-item>   <el-form-item>  <el-button type="primary" size="small" @click="submit()">确定</el-button>  <el-button type="primary" size="small" @click="cancel()">取消</el-button>  </el-form-item>   </el-form> </div></template><script> import {passwordValidator} from '@/common/validator.js' export default { data() {  // 比较两次密码是否相同  const comparePasswdValidator = (rule, value, callback) =>{  // 获取获取值的方法  var getvaluesMethod = rule.getValuesMethod;  // 调用getvaluesMethod方法,获取对象值  var formData = getvaluesMethod();    // 有一个为空,可能还没有输入值,此时不比较  if (formData.newPasswd == '' || formData.confirmPasswd == ''){   return callback();  }  // ===========================================================  // 比较两次密码  // 两个都有值,比较  if (formData.newPasswd == formData.confirmPasswd){   // 新密码与确认密码一致   // 先清除两个密码的校验告警提示,目前是清除另一个密码的不一致的提示   this.$refs['form'].clearValidate(['newPasswd','confirmPasswd']);   callback();  }else{   callback(new Error('两次密码不一致'));  }  }  return {  form : {   oldPasswd : '',   newPasswd : '',   confirmPasswd : ''  },  //用于改变Input类型  password:"password",   //用于更换Input中的图标  icon:"el-input__icon el-icon-view",   // 校验规则配置  rules: {   oldPasswd : [   {required: true, message: "密码不能为空", trigger: 'blur'}   ],     newPasswd : [   {required: true, message: "新密码不能为空", trigger: 'blur'},   {min: 6, max: 18, message: "新密码6-18位", trigger: 'blur'},   {validator: passwordValidator, trigger: 'blur'},   {validator: comparePasswdValidator,trigger: 'blur','getValuesMethod':this.getValuesMethod},   ],    confirmPasswd : [   {required: true, message: "确认密码不能为空", trigger: 'blur'},   {min: 6, max: 18, message: "确认密码6-18位", trigger: 'blur'},   {validator: passwordValidator, trigger: 'blur'},   {validator: comparePasswdValidator,trigger: 'blur','getValuesMethod':this.getValuesMethod},   ],       },    } }, methods: {  // 获取值的方法,为所有需要多字段联合校验的校验器使用  getValuesMethod(){  return this.form;  },  // 密码的隐藏和显示  showPassword(){  //点击图标是密码隐藏或显示  if( this.password=="text"){   this.password="password";   //更换图标   this.icon="el-input__icon el-icon-view";  }else {   this.password="text";   this.icon="el-input__icon el-icon-stopwatch";  }  },   // 提交  submit(){  let _this = this;  this.$refs['form'].validate(valid => {   // 验证通过为true,有一个不通过就是false   if (valid) {   _this.instance.changePasswd(_this.$baseUrl,_this.form).then(res => {    if (res.data.code == _this.global.SucessRequstCode){    // 提示修改成功    alert("重新设置密码已成功!");    // 跳转到首页    this.$router.push({     path: '/home',    });        }else{    if (!_this.commonFuncs.isInterceptorCode(res.data.code)){     alert(res.data.message);    }    }       }).catch(error => {    console.log(error);   });   }     })  },  // 取消  cancel(){  // 跳转到首页  this.$router.push({   path: '/home',  });     } } }</script> 

  导入的外部校验器passwordValidator在/src/common/validator.js文件中,代码如下:

/* 密码校验 */export function passwordValidator(rule, value, callback) { const reg =/^[_a-zA-Z0-9@.#%&*!\-\$^]+$/; if(value == '' || value == undefined || value == null){ callback(); } else { if (!reg.test(value)){  callback(new Error('密码由英文字母、数字以及下列字符组成:@.#%&*!_-$^')); } else {  callback(); } }}

2.2、代码说明

2.2.1、规则配置:

 // 校验规则配置 rules: {  oldPasswd : [  {required: true, message: "密码不能为空", trigger: 'blur'}  ],    newPasswd : [  {required: true, message: "新密码不能为空", trigger: 'blur'},  {min: 6, max: 18, message: "新密码6-18位", trigger: 'blur'},  {validator: passwordValidator, trigger: 'blur'},  {validator: comparePasswdValidator,trigger: 'blur','getValuesMethod':this.getValuesMethod},  ],   confirmPasswd : [  {required: true, message: "确认密码不能为空", trigger: 'blur'},  {min: 6, max: 18, message: "确认密码6-18位", trigger: 'blur'},  {validator: passwordValidator, trigger: 'blur'},  {validator: comparePasswdValidator,trigger: 'blur','getValuesMethod':this.getValuesMethod},  ],      },  

  重点是newPasswd和confirmPasswd属性,两个配置了相同的规则集,校验规则都为:

  • 值不能为空。
  • 长度为6-18位。
  • 符合密码校验器passwordValidator的规则,即密码由英文字母、数字以及下列字符组成:@.#%&*!_-$^。
  • 比较密码校验器comparePasswdValidator,这个校验器添加了一个自定义属性getValuesMethod,属性值为this的getValuesMethod方法,注意是方法,不是方法名。该条规则,要求methods中有一个getValuesMethod方法,并且实现comparePasswdValidator校验器。

  这些规则一起作用,所有规则都通过校验,属性校验才通过,并且检测次序按照数组的先后次序执行。

  校验规则中,newPasswd和confirmPasswd属性,都配置相同的comparePasswdValidator,是因为两个字段属性值都是可变的。comparePasswdValidator排在规则的最后一条,即需要先满足前面的校验规则。

2.2.2、getValuesMethod方法

 // 获取值的方法,为所有需要多字段联合校验的校验器使用 getValuesMethod(){ return this.form; },

  getValuesMethod方法,返回data中form数据对象。这是一个很犀利的操作,相当于提供了全局的数据探针,可以在校验器中访问data的form数据对象,并且由于form的v-modal模型,确保数据的实时性,即无需担心获取不到其它属性的最新取值。getValuesMethod方法,提供了数据绑定的另类思路。

2.2.3、comparePasswdValidator校验器

 // 比较两次密码是否相同 const comparePasswdValidator = (rule, value, callback) =>{ // 获取获取值的方法 var getvaluesMethod = rule.getValuesMethod; // 调用getvaluesMethod方法,获取对象值 var formData = getvaluesMethod();  // 有一个为空,可能还没有输入值,此时不比较 if (formData.newPasswd == '' || formData.confirmPasswd == ''){  return callback(); } // =========================================================== // 比较两次密码 // 两个都有值,比较 if (formData.newPasswd == formData.confirmPasswd){  // 新密码与确认密码一致  // 先清除两个密码的校验告警提示,目前是清除另一个密码的不一致的提示  this.$refs['form'].clearValidate(['newPasswd','confirmPasswd']);  callback(); }else{  callback(new Error('两次密码不一致')); } }

  ......

原文转载:http://www.shaoqun.com/a/862434.html

跨境电商:https://www.ikjzd.com/

logo免费制作:https://www.ikjzd.com/w/1998

一淘网:https://www.ikjzd.com/w/1698

史泰博办公用品:https://www.ikjzd.com/w/2112


本文以校验两次密码的一致性应用,给出两个可变属性值的字段之间的联合校验的典型解决方案。1、前言  本文是前文《VueElement-ui表单校验规则,你掌握了哪些?》针对多字段联合校验的典型应用。  在修改密码时,一般需要确认两次密码一致,涉及2个属性字段。类似的涉及2个属性字段的情况有:日期时间范围,如果两者都有值,则要求:结束时间>=开始时间。数量关系:数量下限<=数量上限。  特
东南亚六国电商市场数据解析:印尼为什么是新手之痛,泰国市场到底有多受欢迎...:https://www.ikjzd.com/articles/133414
中东电商市场见解:https://www.ikjzd.com/articles/133413
亚马逊斥资28亿美元新建AWS云服务区域:https://www.ikjzd.com/articles/133412
针对Google如何通过竞争对手去挖掘关键词?:https://www.ikjzd.com/articles/133421
女人同时跟三个男人 打开腿几个男人一起上:http://lady.shaoqun.com/a/248126.html
托着她的臀一下一下深捣 把校花压在身子底下娇喘:http://lady.shaoqun.com/a/248359.html
老师受不了脱了丝袜裙子坐上去 别急今晚让你弄个够:http://lady.shaoqun.com/m/a/247573.html
女的下面张开照片 喜欢让人㖭我下面:http://lady.shaoqun.com/m/a/247409.html
一对一辅导,全市上门,初中小科目精确计分:http://lady.shaoqun.com/a/413002.html
如何缓解做爱时的痛苦:http://lady.shaoqun.com/a/413003.html
隔几天同一个房间就好了。听听中医怎么说:http://lady.shaoqun.com/a/413004.html
郑州市小升初12所人气民办初中住宿及饮食收集:http://lady.shaoqun.com/a/413005.html

No comments:

Post a Comment