JavaScript Swipe Validation

Because I am making a portal website, I need to use js sliding verification.

original

https://blog.csdn.net/chy555chy/article/details/55294147

html

   <div id="dragContainer">
        <div id="dragBg"></div>
        <div id="dragText"></div>
        <div id="dragHandler" class="dragHandlerBg"></div>
    </div>

css

  <style>
        /* Sliding control container, light gray background */
        #dragContainer {
            position: relative;
            display: inline-block;
            background: #e8e8e8;
            width: 300px;
            height: 50px;
            border: 2px solid #e8e8e8;
        }
        /* The left part of the slider, green background */
        #dragBg {
            position: absolute;
            background-color: #7ac23c;
            width: 0px;
            height: 100%;
        }
        /* Swipe validation container text */
        #dragText {
            position: absolute;
            width: 100%;
            height: 100%;
            /* Center the text horizontally */
            text-align: center;
            /* The text is vertically centered, the percentage cannot be used here, because the percentage is relative to the original line-height, not the div height*/
            line-height: 50px;
            /* Text is not allowed to be selected */
            user-select: none;
            -webkit-user-select: none;
        }
        /* slider */
        #dragHandler {
            position: absolute;
            width: 50px;
            height: 100%;
            cursor: move;
        }
        /* Slider initial background */
        .dragHandlerBg {
            background: #fff no-repeat center url("");
        }
        /* Slider background when authentication is successful */
        .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");

            //slider maximum offset
            var maxHandlerOffset = dragContainer.clientWidth - dragHandler.clientWidth;
            //Whether the verification is successful mark
            var isVertifySucc = false;
            initDrag ();

            function initDrag() {
                dragText.textContent = "Drag slider validation";
                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) {
                /*
                There is no width attribute on the html element, only clientWidth
                offsetX is relative to the current element, clientX and pageX are relative to its parent element

                touches: An array of touch objects representing the currently tracked touch operations.
                targetTouches: An array of Touch objects specific to the event target.
              changedTouches: An array of Touch objects representing what has changed since the last 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;
            }

            //Verification succeeded
            function verifySucc() {
                isVertifySucc = true;
                dragText.textContent = "Verification passed";
                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>

before swiping


after swiping



Guess you like

Origin http://43.154.161.224:23101/article/api/json?id=325781802&siteId=291194637