jQuery與vue分別實現超級簡單的綠色拖動驗證碼功能

来源:https://www.cnblogs.com/moqiutao/archive/2018/01/23/8328664.html
-Advertisement-
Play Games

jquery的綠色拖動驗證功能 在網上看到了一個這樣的問題:那種像拖動滑塊匹配圖形的驗證方式是怎麼實現的?。 突然想到實現一個簡單綠色拖動驗證碼的功能,在網上搜了下,有一個用jquery實現的該功能代碼。 體驗地址:http://yanshi.sucaihuo.com/jquery/8/897/de ...


jquery的綠色拖動驗證功能

在網上看到了一個這樣的問題:那種像拖動滑塊匹配圖形的驗證方式是怎麼實現的?。

突然想到實現一個簡單綠色拖動驗證碼的功能,在網上搜了下,有一個用jquery實現的該功能代碼。

體驗地址:http://yanshi.sucaihuo.com/jquery/8/897/demo/。

其CSS代碼:

#drag{ 
    position: relative;
    background-color: #e8e8e8;
    width: 300px;
    height: 34px;
    line-height: 34px;
    text-align: center;
}
#drag .handler{
    position: absolute;
    top: 0px;
    left: 0px;
    width: 40px;
    height: 32px;
    border: 1px solid #ccc;
    cursor: move;
}
.handler_bg{
    background: #fff url("") no-repeat center;
}
.handler_ok_bg{
    background: #fff url("") no-repeat center;
}
#drag .drag_bg{
    background-color: #7ac23c;
    height: 34px;
    width: 0px;
}
#drag .drag_text{
    position: absolute;
    top: 0px;
    width: 300px;
    -moz-user-select: none;
    -webkit-user-select: none;
    user-select: none;
    -o-user-select:none;
    -ms-user-select:none; 
}

HTML代碼結構:

<center style="margin-top: 100px">
        <div id="drag"></div>
</center>

JS調用方式:

 $('#drag').drag();

JS實現代碼:

(function($){
    $.fn.drag = function(options){
        var x, drag = this, isMove = false, defaults = {
        };
        var options = $.extend(defaults, options);
        //添加背景,文字,滑塊
        var html = '<div class="drag_bg"></div>'+
                    '<div class="drag_text" onselectstart="return false;" unselectable="on">拖動滑塊驗證</div>'+
                    '<div class="handler handler_bg"></div>';
        this.append(html);
        
        var handler = drag.find('.handler');
        var drag_bg = drag.find('.drag_bg');
        var text = drag.find('.drag_text');
        var maxWidth = drag.width() - handler.width();  //能滑動的最大間距
        
        //滑鼠按下時候的x軸的位置
        handler.mousedown(function(e){
            isMove = true;
            x = e.pageX - parseInt(handler.css('left'), 10);
        });
        
        //滑鼠指針在上下文移動時,移動距離大於0小於最大間距,滑塊x軸位置等於滑鼠移動距離
        $(document).mousemove(function(e){
            var _x = e.pageX - x;
            if(isMove){
                if(_x > 0 && _x <= maxWidth){
                    handler.css({'left': _x});
                    drag_bg.css({'width': _x});
                }else if(_x > maxWidth){  //滑鼠指針移動距離達到最大時清空事件
                    dragOk();
                }
            }
        }).mouseup(function(e){
            isMove = false;
            var _x = e.pageX - x;
            if(_x < maxWidth){ //滑鼠鬆開時,如果沒有達到最大距離位置,滑塊就返回初始位置
                handler.css({'left': 0});
                drag_bg.css({'width': 0});
            }
        });
        
        //清空事件
        function dragOk(){
            handler.removeClass('handler_bg').addClass('handler_ok_bg');
            text.text('驗證通過');
            drag.css({'color': '#fff'});
            handler.unbind('mousedown');
            $(document).unbind('mousemove');
            $(document).unbind('mouseup');
        }
    };
})(jQuery);

VUE的綠色拖動驗證功能

HTML結構:

<template>
    <div id="drag">
        <div class="drag_bg weui-btn_primary" :style="{width:curW+'px'}"></div>
        <div class="drag_text" onselectstart="return false;" unselectable="on":class="[isDragOk ? 'whitecolor':'']">{{text}}</div>
        <div class="handler" :style="{left:curW+'px'}" :class="[isDragOk ? 'handler_ok_bg':'handler_bg']"></div>
    </div>
</template>

CSS代碼:

<style scoped>
#drag {
    position: relative;
    background-color: #e8e8e8;
    width: 100%;
    height: 36px;
    line-height: 36px;
    text-align: center;
}
#drag .drag_bg {
    height: 36px;
    width:0;
}
#drag .drag_text {
    position: absolute;
    top: 0px;
    width: 100%;
    -moz-user-select: none;
    -webkit-user-select: none;
    user-select: none;
    -o-user-select: none;
    -ms-user-select: none;
}
.drag_text.whitecolor{
    color:#fff;
}
#drag .handler {
    position: absolute;
    top: 0px;
    left: 0px;
    width: 40px;
    height: 34px;
    border: 1px solid #ccc;
    cursor: move;
}
.handler_bg {
    background:#fff url("") no-repeat center
}
.handler_ok_bg {
    background:#fff url("") no-repeat center
}
</style>

JS代碼:

<script>
export default{
    name:'slider',
    props:{
        
    },
    data(){
        return{
            curW:0,
            isMove:false, //是否在運動
            isDragOk:false, //是否拖動成功
            maxWidth:0, //拖動的最大寬度
            element:{},
            text:'拖動滑塊驗證',
            currentPos:{
                x: 0,
                y: 0
            }
        }
    },
    created(){
        
    },
    mounted () {
        var self = this;
        this.element = document.querySelector('.handler');
        this.getMaxWidth();
        window.addEventListener('resize',function(){self.getMaxWidth()});
        window.addEventListener('orientationchange',function(){self.getMaxWidth()});
        
        
          this.element.addEventListener('touchstart',self.touchstartFun,false);
        document.querySelector('body').addEventListener('touchmove',self.touchmoveFun,false);
        document.querySelector('body').addEventListener('touchend',self.touchendFun,false);
        
        this.element.addEventListener('mousedown',self.touchstartFun,false);
        document.querySelector('body').addEventListener('mousemove',self.touchmoveFun,false);
        document.querySelector('body').addEventListener('mouseup',self.touchendFun,false);
        
        (function drawAnimate() {
            if( self.curW <= self.maxWidth){
                window.requestAnimFrame(drawAnimate,1000/60);
                self.curW = self.currentPos.x;
            }else{
                self.curW = self.currentPos.x = self.maxWidth;
            }
        })();
    },
    watch:{
        
    },
    methods:{
        touchstartFun(e){
            if(this.isDragOk){
                  e.preventDefault();
                  return;
              }
            this.isMove = true;
            this.curW = this.currentPos.x = this.getCurrentPosition(e).x;
        },
        touchmoveFun(e){
            if(this.isMove && this.curW > 0 && this.curW < this.maxWidth){
                this.currentPos.x = this.getCurrentPosition(e).x;
            }
            else if(this.isMove && this.curW >= this.maxWidth){
                this.curW = this.currentPos.x = this.maxWidth;
                this.isDragOk = true;
                this.text = "驗證通過";
            }
        },
        touchendFun(e){
            this.isMove = false;
            if(this.curW < this.maxWidth){
                this.curW = this.currentPos.x = 0;
            }
        },
        
        getCurrentPosition(event){
            var xPos, yPos, rect;
            rect = document.getElementById('drag').getBoundingClientRect();
            //event = event.originalEvent;
            //判斷是touch,還是滑鼠事件
            if (event.type.indexOf('touch') !== -1) {
                xPos = event.touches[0].clientX - rect.left;
                yPos = event.touches[0].clientY - rect.top;
            }
            
            //滑鼠事件
            else {
                xPos = event.clientX - rect.left;
                yPos = event.clientY - rect.top;
            }
            return {
                x: xPos,
                y: yPos
            }
        },
        getMaxWidth(){
            this.maxWidth = document.querySelector("#drag").clientWidth - document.querySelector(".handler").scrollWidth;
        }
    }
}
</script>

頁面引用方式:

<slider></slider>

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 模塊載入過程: 路徑分析 文件定位 模塊編譯 Node對引入過的模塊都會進行緩存,以減少二次引入時的開銷。緩存的是編譯和執行之後的對象。require時對緩存中的模塊是第一優先順序的 路徑分析 模塊標識符:require的參數,按書寫形式可以分成以下幾類: 核心模塊:如http,fs,path 文件模 ...
  • 轉載請註明出處: "Generator函數非同步應用" 上一篇文章詳細的介紹了Generator函數的語法,這篇文章來說一下如何使用Generator函數來實現非同步編程。 或許用Generator函數來實現非同步會很少見,因為ECMAScript 2016的async函數對Generator函數的流程式控制 ...
  • 介紹HTTP緩存之前先簡單說一下Web緩存 Web緩存是一種保存Web資源副本併在下次請求時直接使用該副本的技術。        Web緩存可以分為這幾種:瀏覽器緩存、CDN緩存、伺服器緩存、資料庫數據緩存 。因為可能會直接使用副 ...
  • 本文設計到常見對文檔的處理樣式,和塊,行標簽的特點。 沒用什麼重要內容,只是自己的一些知識點的回憶,對以前知識的一個梳理過程,望某懶蟲加油!!! ...
  • classList屬性的方法:add();remove();toggle(); 描述,在一些頁面我們需要使用兩個按鈕來回切換,如圖: 我們要使用到add()和remove()方法 html部分: <div class="login-title"> <a href="javascript:void(0 ...
  • 2017年npm上最熱門的項目之一——Pkg,可以直接將node.js項目打包成windows可以直接執行的exe文件(也支持FreeBSD、linux、macos、arm系統),並且無須修改你項目中的任何代碼。本文對該項目作了簡要說明與教程,並提供了一個簡單示例來說明其使用場景。 ...
  • CreateJS介紹請看CreateJS中文網或者官方網站 一.使用EaselJS 先到官網下載easeljs,也可以點這裡 1.得到easeljs-0.8.1.min.js後,新建一個HTML5文件並導入: 2.入口函數和創建canvas標簽: 3.創建舞臺: 二.使用EaselJS創建圖形和文字 ...
  • css代碼: html代碼: JS調用: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...