滑动验证
原文
https://blog.csdn.net/chy555chy/article/details/55294147
html
<p id="dragcontainer">
<p id="dragBg"></p>
<p id="dragText"></p>
<p id="draghandler" class="dragHandlerBg"></p>
</p>
css
<style>
/* 滑动控件容器,亮灰色背景 */
#dragContainer {
position: relative;
display: inline-block;
background: #e8e8e8;
width: 300px;
height: 50px;
border: 2px solid #e8e8e8;
}
/* 滑块左边部分,绿色背景 */
#dragBg {
position: absolute;
background-color: #7ac23c;
width: 0px;
height: 100%;
}
/* 滑动验证容器文本 */
#dragText {
position: absolute;
width: 100%;
height: 100%;
/* 文字水平居中 */
text-align: center;
/* 文字垂直居中,这里不能用百分比,因为百分比是相对原始line-height的,而非p高度 */
line-height: 50px;
/* 文本不允许选中 */
user-select: none;
-webkit-user-select: none;
}
/* 滑块 */
#dragHandler {
position: absolute;
width: 50px;
height: 100%;
cursor: move;
}
/* 滑块初始背景 */
.dragHandlerBg {
background: #fff no-repeat center url("");
}
/* 验证成功时的滑块背景 */
.dragHandlerOkBg {
background: #fff no-repeat center url("");
}
</style>
<script>
window.onload = function() {
var dragContainer = document.getelementbyid("dragContainer");
var dragBg = document.getElementById("dragBg");
var dragText = document.getElementById("dragText");
var dragHandler = document.getElementById("dragHandler");
//滑块最大偏移量
var maxHandleroffset = dragContainer.clientwidth - dragHandler.clientWidth;
//是否验证成功的标记
var isVertifySucc = false;
initDrag();
function initDrag() {
dragText.textcontent = "拖动滑块验证";
dragHandler.addeventlistener("mousedown", onDragHandlerMouseDown);
dragHandler.addEventListener("touchstart", onDragHandlerMouseDown);
}
function onDragHandlerMouseDown(event) {
document.addEventListener("mousemove", onDragHandlerMouseMove);
document.addEventListener("mouseup", onDragHandlerMouseUp);
document.addEventListener("touchmove", onDragHandlerMouseMove);
document.addEventListener("touchend", onDragHandlerMouseUp);
}
function onDragHandlerMouseMove(event) {
/*
html元素不存在width属性,只有clientWidth
offsetX是相对当前元素的,clientX和pageX是相对其父元素的
touches:表示当前跟踪的触摸操作的touch对象的数组。
targetTouches:特定于事件目标的Touch对象的数组。
changedTouches:表示自上次触摸以来发生了什么改变的Touch对象的数组。
*/
var left = (event.clientX || event.changedTouches[0].clientX) - dragHandler.clientWidth / 2;
if(left < 0) {
left = 0;
} else if(left > maxHandlerOffset) {
left = maxHandlerOffset;
verifySucc();
}
dragHandler.style.left = left + "px";
dragBg.style.width = dragHandler.style.left;
}
function onDragHandlerMouseUp(event) {
document.removeEventListener("mousemove", onDragHandlerMouseMove);
document.removeEventListener("mouseup", onDragHandlerMouseUp);
document.removeEventListener("touchmove", onDragHandlerMouseMove);
document.removeEventListener("touchend", onDragHandlerMouseUp);
dragHandler.style.left = 0;
dragBg.style.width = 0;
}
//验证成功
function verifySucc() {
isVertifySucc = true;
dragText.textContent = "验证通过";
dragText.style.color = "white";
dragHandler.setAttribute("class", "dragHandlerOkBg");
dragHandler.removeEventListener("mousedown", onDragHandlerMouseDown);
document.removeEventListener("mousemove", onDragHandlerMouseMove);
document.removeEventListener("mouseup", onDragHandlerMouseUp);
dragHandler.removeEventListener("touchstart", onDragHandlerMouseDown);
document.removeEventListener("touchmove", onDragHandlerMouseMove);
document.removeEventListener("touchend", onDragHandlerMouseUp);
};
}
</script>
滑动之前
滑动之后
相关阅读
还记得以前那篇《超强验证码》?其实这个世界变态的验证码还有很多,下面是一个列表向像展示了各种稀奇古怪的验证码。不过本文并不
在短信验证码的产品设计过程中有哪些事项是需要注意的呢?短信验证码如今的应用之广无需赘述,各大银行的网上银行、各种手机APP、各
试了几种方法,还是 translateY 比较靠谱 放弃 ie // 固定头部 var thead_top = $('thead').offset().top; $(window).scroll(fun
作为产品经理来说,什么时候能脱离对原型和功能的思考,更多的关注“产品”本身,才算是真正成长为一名产品经理。无论我们去做哪个产品
注册微软账户失败无法查看验证example.com邮箱该怎么
注册微软账户失败无法查看验证邮箱该怎么办?新的Windows 10 发布后,好多网友们都装上了它,在使用中为了能和小娜对话,都去注册了微软