本篇文章给大家分享的是有关使用原生JavaScript实现拖动校验功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
思路
1、页面布局采用定位,背景颜色变化bg的宽度为0,其宽度会随着滑块的移动而移动。
页面结构
<!--验证-->
<div class="box">
<!--滑块-->
<div class="btn"></div>
<!--文字-->
<p class="text">请滑动滑块</p>
<!--背景-->
<div class="bg"></div>
</div>
页面布局
/* 滑块使用定位,背景没有设置宽度*/
.box {
width: 250px;
height: 50px;
background-color: #ccc;
position: relative;
margin: 0 auto;
}
.btn {
box-sizing: border-box;
width: 50px;
height: 50px;
border: 1px solid #ccc;
color: #ccc;
background-color: #fff;
position: absolute;
left: 0;
top: 0;
cursor: pointer;
z-index: 4;
}
.text {
position: absolute;
height: 50px;
left: 50%;
transform: translateX(-50%);
z-index: 2;
user-select: none;
}
.bg {
width: 0;
height: 50px;
background-color: #25c20f;
z-index: 3;
position: absolute;
top: 0;
left: 0;
}
2、分析事件—鼠标按下,鼠标移动,鼠标松开
2.1 鼠标按下,获取此时事件的水平距离downX;鼠标移动,获取此时事件的水平距离e.clientX;那么鼠标移动的距离moveX = e.clientX - downX,也就是滑块跟着移动的距离。即btn.style.left = moveX + 'px';同时bg的宽度也就是滑块移动的距离,即bg.style.width = moveX + 'px'
2.2 滑块拉到头了,表示验证成功
什么时候表示滑块滑到头了,也就是moveX等于box的宽度-滑块的宽度。那么文字的改变成“验证成功”。且滑块停留在了最有端。无论鼠标点击还是移动,都不会在影响了。那就是清除事件,清除按钮的鼠标移动和鼠标按下事件btn.onmousemove = null; btn.onmousedown = null;//清除事件
此时验证成功,设立一个标记为表示验证成功flag=true,后续需要用到。
2.3 那么如果我们滑块拉到一半就松开了鼠标,滑块应该回到原始位置。但是如果已经验证成功了,那就不会回到原点。
鼠标松开事件触发,那么鼠标移动已经不能影响滑块了,那么此时需要清除移动事件btn.onmousemove = null;没有验证成功那就回到原点this.style.left = 0; bg.style.width = 0;
页面动作
function selector(name) {
return document.querySelector(name);
}
var box = selector('.box'),
btn = selector('.btn'),
text = selector('.text'),
bg = selector('.bg'),
flag = false;
// 鼠标按下,移动,松开
// 按下的距离和移动的距离差就是滑块移动的距离
btn.onmousedown = function (e) {//按钮按下的
var downX = e.clientX
btn.onmousemove = function(e){//e 事件的状态
var moveX = e.clientX - downX;
if(moveX > 0) {
this.style.left = moveX + 'px';
bg.style.width = moveX + 'px'
// 滑块拉到头了,表示验证成功
if (moveX >= box.offsetWidth - this.offsetWidth) {
bg.style.zIndex = 1;// 设置bg的z-index的值是为了处理党滑块经过原始值的时候,bg将文字覆盖了。验证成功后,有让文字显示出来
text.innerText = '验证成功';
text.style.color = '#fff';
flag = true;
// 此时鼠标移动或者按下,滑块不在跟着移动了
btn.onmousemove = null;//
btn.onmousedown = null;//清除事件
}
}
}
}
btn.onmouseup = function () {
btn.onmousemove = null;
// 如果验证成功了,那就不会回到原点
if(flag){
return ;
}
this.style.left = 0;
bg.style.width = 0;
}
完整可以运行的源码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
/* 滑块使用定位,背景没有设置宽度*/
.box {
width: 250px;
height: 50px;
background-color: #ccc;
position: relative;
margin: 0 auto;
}
.btn {
box-sizing: border-box;
width: 50px;
height: 50px;
border: 1px solid #ccc;
color: #ccc;
background-color: #fff;
position: absolute;
left: 0;
top: 0;
cursor: pointer;
z-index: 4;
}
.text {
position: absolute;
height: 50px;
left: 50%;
transform: translateX(-50%);
z-index: 2;
user-select: none;
}
.bg {
width: 0;
height: 50px;
background-color: #25c20f;
z-index: 3;
position: absolute;
top: 0;
left: 0;
}
</style>
</head>
<body>
<!--验证-->
<div class="box">
<!--滑块-->
<div class="btn"></div>
<!--文字-->
<p class="text">请滑动滑块</p>
<!--背景-->
<div class="bg"></div>
</div>
<script>
function selector(name) {
return document.querySelector(name);
}
var box = selector('.box'),
btn = selector('.btn'),
text = selector('.text'),
bg = selector('.bg'),
flag = false;
// 鼠标按下,移动,松开
// 按下的距离和移动的距离差就是滑块移动的距离
btn.onmousedown = function (e) {//按钮按下的
var downX = e.clientX
btn.onmousemove = function(e){//e 事件的状态
var moveX = e.clientX - downX;
if(moveX > 0) {
this.style.left = moveX + 'px';
bg.style.width = moveX + 'px'
// 滑块拉到头了,表示验证成功
if (moveX >= box.offsetWidth - this.offsetWidth) {
bg.style.zIndex = 1;// 设置bg的z-index的值是为了处理党滑块经过原始值的时候,bg将文字覆盖了。验证成功后,有让文字显示出来
text.innerText = '验证成功';
text.style.color = '#fff';
flag = true;
// 此时鼠标移动或者按下,滑块不在跟着移动了
btn.onmousemove = null;//
btn.onmousedown = null;//清除事件
}
}
}
}
btn.onmouseup = function () {
btn.onmousemove = null;
// 如果验证成功了,那就不会回到原点
if(flag){
return ;
}
this.style.left = 0;
bg.style.width = 0;
}
</script>
</body>
</html>
以上就是使用原生JavaScript实现拖动校验功能,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。