欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue 登录滑动验证实现代码

程序员文章站 2024-01-01 13:08:52
在没给大家讲解实现代码之前,先给大家分享效果图: 之前别人都是用jq写的,自己整理了一下开始使用

在没给大家讲解实现代码之前,先给大家分享效果图:

vue 登录滑动验证实现代码

vue 登录滑动验证实现代码

之前别人都是用jq写的,自己整理了一下开始使用

<el-form-item label="验证">
<div class="form-inline-input">
<div class="code-box" id="code-box">
<input type="text" name="code" class="code-input" />
<p></p>
<span>>>></span>
</div>
</div>
</el-form-item>

vue代码

//获取元素距离页面边缘的距离
getoffset(box,direction){
var setdirection = (direction == 'top') ? 'offsettop' : 'offsetleft' ;
var offset = box[setdirection];
var parentbox = box.offsetparent;
while(parentbox){
offset+=parentbox[setdirection];
parentbox = parentbox.offsetparent;
}
parentbox = null;
return parseint(offset);
},
 movecode(code,_this){
var fn = {codevluae : code};
var box = document.queryselector("#code-box"),
progress = box.queryselector("p"),
codeinput = box.queryselector('.code-input'),
evenbox = box.queryselector("span");
//默认事件
var boxeven = ['mousedown','mousemove','mouseup'];
//改变手机端与pc事件类型
if(typeof document.ontouchstart == 'object'){
boxeven = ['touchstart','touchmove','touchend'];
}
var gox,offsetleft,deviation,evenwidth,endx;
function movefn(e){
e.preventdefault();
e = (boxeven['0'] == 'touchstart') ? e.touches[0] : e || window.event;
endx = e.clientx - gox;
endx = (endx > 0) ? (endx > evenwidth) ? evenwidth : endx : 0;
if(endx > evenwidth * 0.7){
progress.innertext = '松开验证';
progress.style.backgroundcolor = "#66cc66";
}else{
progress.innertext = '';
progress.style.backgroundcolor = "#ffff99";
}
progress.style.width = endx+deviation+'px';
evenbox.style.left = endx+'px';
}
function removefn() {
document.removeeventlistener(boxeven['2'],removefn,false);
document.removeeventlistener(boxeven['1'],movefn,false);
if(endx > evenwidth * 0.7){
progress.innertext = '验证成功';
progress.style.width = evenwidth+deviation+'px';
evenbox.style.left = evenwidth+'px'
codeinput.value = fn.codevluae;
evenbox.onmousedown = null;
_this.ruleform.verification = true;
}else{
progress.style.width = '0px';
evenbox.style.left = '0px';
}
};
function getoffset(box,direction){
var setdirection = (direction == 'top') ? 'offsettop' : 'offsetleft' ;
var offset = box[setdirection];
var parentbox = box.offsetparent;
while(parentbox){
offset+=parentbox[setdirection];
parentbox = parentbox.offsetparent;
}
parentbox = null;
return parseint(offset);
};
evenbox.addeventlistener(boxeven['0'], function(e) {
e = (boxeven['0'] == 'touchstart') ? e.touches[0] : e || window.event;
gox = e.clientx,
offsetleft = getoffset(box,'left'),
deviation = this.clientwidth,
evenwidth = box.clientwidth - deviation,
endx;
document.addeventlistener(boxeven['1'],movefn,false);
document.addeventlistener(boxeven['2'],removefn,false);
},false);
fn.setcode = function(code){
if(code)
fn.codevluae = code;
}
fn.getcode = function(){
return fn.codevluae;
}
fn.resetcode = function(){
evenbox.removeattribute('style');
progress.removeattribute('style');
codeinput.value = '';
};
return fn;
 }

调用

mounted(){
var _this = this;
// window.addeventlistener('load',function(){
//code是后台传入的验证字符串
var code = "jsaidaisd656",
codefn = new _this.movecode(code,_this);
// });
}

验证样式

.form-inline-input{
 border:1px solid #dadada;
border-radius:5px;
}
.form-inline-input input,
.code-box{
 padding: 0 3px;
width: 298px;
height: 40px;
color: #fff;
text-shadow: 1px 1px 1px black;
background: #efefef;
border: 0;
border-radius: 5px;
 outline: none;
}
.code-box{
 position: relative;
}
.code-box p,
.code-box span{
 display:block;
 position: absolute;
 left: 0;
 height: 40px;
 text-align: center;
 line-height: 40px;
 border-radius: 5px;
padding:0;
margin:0;
}
.code-box span{
 width: 40px;
 background-color:#fff;
 font-size: 16px;
 cursor: pointer;
margin-right:1px;
}
.code-box p{
 width: 0;
 background-color: #ffff99;
 overflow: hidden;
 text-indent: -20px;
 transition: background 1s ease-in;
}
.code-box .code-input{
 display: none;
}
.code-box .code-input{
 display: none;
}
.form-inline-input{
 border:1px solid #dadada;
border-radius:5px;
}
.form-inline-input input,
.code-box{
 padding: 0 3px;
width: 298px;
height: 40px;
color: #fff;
text-shadow: 1px 1px 1px black;
background: #efefef;
border: 0;
border-radius: 5px;
 outline: none;
}
.code-box{
 position: relative;
}
.code-box p,
.code-box span{
 display:block;
 position: absolute;
 left: 0;
 height: 40px;
 text-align: center;
 line-height: 40px;
 border-radius: 5px;
padding:0;
margin:0;
}
.code-box span{
 width: 40px;
 background-color:#fff;
 font-size: 16px;
 cursor: pointer;
margin-right:1px;
}
.code-box p{
 width: 0;
 background-color: #ffff99;
 overflow: hidden;
 text-indent: -20px;
 transition: background 1s ease-in;
}
.code-box .code-input{
 display: none;
}
.code-box .code-input{
 display: none;
}

总结

以上所述是小编给大家介绍的vue 登录滑动验证实现代码,希望对大家有所帮助

上一篇:

下一篇: