Skip to content

Instantly share code, notes, and snippets.

@edwardlorilla
Created June 6, 2021 16:12
Show Gist options
  • Save edwardlorilla/d0394de6b74b4be13a729bd070577161 to your computer and use it in GitHub Desktop.
Save edwardlorilla/d0394de6b74b4be13a729bd070577161 to your computer and use it in GitHub Desktop.
【JavaScript html 】 sliding verification
<div id="dragContainer"><!-- Initial background of container -->
<div id="dragBg"></div><!-- Green background -->
<div id="dragText"></div><!-- Sliding container text -->
<div id="dragHandler" class="dragHandlerBg"></div>
</div> <!-- Slider Initial background of the slider -->
//Load (the event will be triggered after the page is loaded)
window.onload = function() {
//Get the sliding control container, gray background
var dragContainer = document.getElementById("dragContainer");
//Get the left part of the slider, green background
var dragBg = document.getElementById("dragBg");
//Get the sliding verification container text
var dragText = document.getElementById("dragText");
//Get the slider
var dragHandler = document.getElementById("dragHandler");
//The maximum offset of the slider = the text length of the sliding verification container-the length of the slider
var maxHandlerOffset = dragContainer.clientWidth-dragHandler.clientWidth;
//Whether the verification is successful
var isVertifySucc = false;
initDrag();
function initDrag() {
//Write "drag slider verification" in the sliding verification container text
dragText.textContent = "Drag the slider to verify";
//Add mouse press monitoring to the slider
dragHandler.addEventListener("mousedown", onDragHandlerMouseDown);
}
//Select the slider
function onDragHandlerMouseDown() {
//Mouse movement monitoring
document.addEventListener("mousemove", onDragHandlerMouseMove);
//Release the mouse to
document.addEventListener("mouseup", onDragHandlerMouseUp);
}
//Sliders move
function onDragHandlerMouseMove() {
/*
There is no width attribute for html elements, only clientWidth
offsetX is relative to the current element, clientX and pageX are relative to its parent element
*/
//The amount of slider movement
var left = event.clientX-dragHandler.clientWidth / 2;
//
if(left <0) {
left = 0;
//If the movement of the slider> the maximum offset of the slider, call the verification success function
} else if(left> maxHandlerOffset) {
left = maxHandlerOffset;
verifySucc();
}
//The amount of slider movement
dragHandler.style.left = left + "px";
//The length of the green background
dragBg.style.width = dragHandler.style.left;
}
//Release the slider function
function onDragHandlerMouseUp() {
//Remove mouse movement monitoring
document.removeEventListener("mousemove", onDragHandlerMouseMove);
//Remove the mouse and release the monitor
document.removeEventListener("mouseup", onDragHandlerMouseUp);
//Initialize the movement of the slider
dragHandler.style.left = 0;
//Initialize the green background
dragBg.style.width = 0;
}
//Verification is successful
function verifySucc() {
//Successful mark, no rebound
isVertifySucc = false;
//The text of the container text is changed to white "verification passed" font
dragText.textContent = "Verification passed";
dragText.style.color = "white";
//Verify the background of the slider passed
dragHandler.setAttribute("class", "dragHandlerOkBg");
//Remove mouse press monitoring
dragHandler.removeEventListener("mousedown", onDragHandlerMouseDown);
//Remove mouse movement monitoring
document.removeEventListener("mousemove", onDragHandlerMouseMove);
//Remove the mouse and release the monitor
document.removeEventListener("mouseup", onDragHandlerMouseUp);
// After the match is successful, write the page you want to jump to
//window.location.href="success page.html" rel="external nofollow";
};
}
#dragContainer {
position: relative;
display: inline-block;
background: #e8e8e8;
width: 300px;
height: 33px;
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: 33px;
user-select: none;
-webkit-user-select: none;
}
#dragHandler {
position: absolute;
width: 40px;
height: 100%;
cursor: move;
}
.dragHandlerBg {
background: #fff no-repeat center url("");
}
.dragHandlerOkBg {
background: #fff no-repeat center url("");
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment