您现在的位置是:网站首页>前端技术>uniappuniapp

uniapp 发送验证码前弹窗显示滑动图形验证码

神夜2020-08-05 14:16:29uniapp1714人已围观文章来源:神夜个人博客

简介发送验证码前弹窗显示滑动图形验证码

效果图


实现代码:

一、插件 compntents/verfiy.vue


<template>
 <view class="cont">
  <view class="shuaxin" :style="{ transform: 'rotate(' + rotate + 'deg)' }" @click="refresh">view>
  <view class="title">图形验证view>
  <view class="imgWrap">
   <image class="img" :src="src" mode="aspectFill">image>
   <view class="smartImg" :style="'top:'+top+'px;left:'+sleft+'px'"><image class="simg" :src="smartSrc">image>view>
  view>
  <view class="sliderBox" @touchend="sliderEnd">
   <movable-area class="sliderF">
    <movable-view :animation="trueclass="sliderS" :x="sliderx" direction="horizontal" @change="startMove">
     <image class="icon" src="/static/images/rr.png" mode="">image>
    movable-view>
   movable-area>
   <view class="bgC">
    拖动左边滑块完成上方拼图
    <view class="bgC_left" :style="{ width: backLeft + 'px' }">view>
   view>
  view>
  <view class="showMessage" :style="{ color: acColor }">{{ message }}view>
  <image src="/static/images/close3.png" @tap="closeVerify" class="close" />
 view>
template>

<script>
export default {
 name: 'verfiy',
 props: {
  show: {
   type: Boolean,
   default: false
  }
 },
 watch: {
  show(v) {
   if(v==true){
     console.log(11);
     this.initVerfiy();
   }
  }
 },
 data() {
  return {
   left: 0,   //小图块初始左位置
   top: 0,    //返回距离顶位置
   sleft: 0,  //当前小块滑动距离  
   sliderx: 0,
   backLeft: 0//滑块当前宽
   bgC_color: ''
   message: ''//错误消息
   acColor: '#333',
   src: '',     //图片
   smartSrc:'' ,//小块图
   capCode:'',
   rotate:0,
  };
 },
 mounted() {
   if(this.show==true){
     this.initVerfiy();
   }
 },
 methods: {
  
  //初始化验证码图  
  async initVerfiy() {
    const json = await this.api.apiArray.getVerfiyPic({noLoading:true});
    if(json.data.returnCode==0){
       this.src = json.data.result.bigImage;
       this.smartSrc = json.data.result.smallImage;
       this.top = json.data.result.yHeight;
       this.left = Math.floor(10 * Math.random());
       this.capCode = json.data.result.capCode;
       this.sliderx = 1;
       setTimeout(() => { this.sliderx = 0;}, 300);
    }  
  },
  
  //滑动开始
  startMove(e) {
   this.backLeft = e.detail.x + 18;
   this.sleft = this.left + e.detail.x;
  },
  
  //滑动结束验证
  async sliderEnd() {
   let that = this;
   const json = await this.api.apiArray.checkCapCode({method:'post',query:{xPos:parseInt(this.sleft),capCode:this.capCode},noLoading:true});
   if(json.data.returnCode==0){
     this.message = '验证成功!';
     this.acColor = 'green';
     setTimeout(() => {      
       that.message = '';
       that.sliderx = 1;
       this.backLeft = 0;
       setTimeout(() => { that.sliderx = 0; }, 300);
       this.$emit('success',this.capCode);
     }, 1000);
   } else {
     this.message = '验证失败,请重试';
     this.acColor = 'red';
     setTimeout(() => {
       that.message = '';
       that.sliderx = 1;
       setTimeout(() => { that.sliderx = 0; }, 300);
       that.initVerfiy();
     }, 1000);
   }
  },
    
  closeVerify(){
     this.$emit('close')
  },
  
  refresh(){
    this.rotate = this.rotate + 180;
    this.initVerfiy();
  }
  
 }
};
script>

<style lang="scss" scoped>
@mixin flexC {
 displayflex;
 align-itemscenter;
 justify-contentcenter;
}

.cont {
 z-index:3333;
 background#fff;
 width:280px;
 border-radius8px;
 .shuaxin {
  positionabsolute;
  right20rpx;
  top20px;
  width40rpx;
  height40rpx;
  backgroundurl(-repeat;
  background-sizecover;
  transitionall 0.3s;
 }
 .title {
  width100%;
  height60px;
  font-size18px;
  color#333;
  @include flexC;
 }

 .imgWrap {
  positionrelative;
  width260px;
  height150px;
  border-radius8px;
  margin0 auto;
  overflowhidden;
  background#ddd;
  .img {
   displayblock;
   width100%;
   height100%;
  }

  .over {
   positionabsolute;
   left0;
   top0;
   width50px;
   height50px;
   background#ddd;
   box-shadowinset 0 0 5px rgba(0000.3);
  }

  .smartImg {
   positionabsolute;
   z-index2;
   left0;
   top0;
   width55px;
   height45px;
   overflowhidden;
   .simg {    
    displayblock;
    width100%;
    height100%;
   }
  }
 }
}

.sliderBox {
 width260px;
 margin10px auto 0;
 height36px;
 positionrelative;

 .sliderF {
  width100%;
  height100%;
  z-index3;

  .sliderS {
   height36px;
   width36px;
   background#007cff;
   border-radius36px;
   displayflex;
   justify-contentcenter;
   align-itemscenter;

   .icon {
    width20px;
    height20px;
   }
  }
 }

 .bgC {
  positionabsolute;
  z-index1;
  left0;
  top50%;
  transformtranslateY(-50%);
  width100%;
  height30px;
  border-radius30px;
  line-height30px;
  font-size14px;
  color#999999;
  box-shadowinset 0 0 4px #ccc;
  text-aligncenter;
  overflowhidden;
 }

 .bgC_left {
  positionabsolute;
  left0;
  top50%;
  transformtranslateY(-50%);
  width0;
  height28px;
  border-top-left-radius28px;
  border-bottom-left-radius28px;
  line-height28px;
  font-size14px;
  background-color#eee;
  box-shadowinset 0 0 4px #ccc;
  text-aligncenter;
 }
}
.showMessage {
 text-aligncenter;
 font-size14px;
 height30px;
 line-height30px;
}
.closewidth:30pxheight:30pxposition:absoluteleft:0right:0margin:autobottom:-40px;}
style>


二、使用


<template>
 <view>
  <view @tap="openVerfiy">显示图形验证码view>
  <uni-popup ref="popup" type="center">
      <Verify :show="showVerfiy" v-on:close="closeVerify" v-on:success="verfiySuceess" />
    uni-popup>    
 view>
template>

<script>
 import uniPopup from '@/components/uni-popup/uni-popup.vue'
 import Verify from '@/components/verify.vue'
export default {
 components:{uniPopup,Verify},
 data() {
  return {
     showVerfiy:false,
  };
 },
 mounted() {
   
 },
 methods: {
    
    openVerfiy(){
      this.showVerfiy = true;
      this.$refs.popup.open();
    }

    //图形验证通过
     verfiySuceess(e){
       this.capCode = e;
       this.closeVerify();
       //通过后进行其它操作
     },
     
     //关闭图形验证
     closeVerify(){
        this.showVerfiy = false;
        this.$refs.popup.close();
     }, 
  
 }
};
script>



注:后台接口返回背景图和小方块图以及小方块图距离顶部的高。然后检测的时候把当前小方块移动距离左的距离和后台返回的code 一起提交给后台验证



站点信息

  • 建站时间:2017-10-24
  • 网站程序:Hsycms 3.0
  • 文章统计:288条
  • 微信公众号:扫描二维码,关注我们
分享按钮