Vue 實現(xiàn)拖動滑塊驗證功能(只有css+js沒有后臺驗證步驟)
更新時間:2018年08月24日 09:58:12 作者:想轉行的入門級程序員
這篇文章給大家介紹了基于vue實現(xiàn)拖動滑塊驗證功能,代碼引用css與js都是線上的,將代碼全部復制到一個html中可以直接打開,超級簡單,感興趣的朋友跟隨腳本之家小編一起看看吧
vue驗證滑塊功能,在生活中很多地方都可以見到,那么使用起來非常方便,基于vue如何實現(xiàn)滑塊驗證呢?下面通過代碼給大家講解。
效果圖如下所示:
拖動前
拖動后
代碼引用的css與js都是線上的
將代碼全部復制到一個html中可以直接打開,極其簡單。
來分析一下代碼
底色div上放了一個變色div再放一個提示字的div最后加一個滑塊div
給滑塊div綁定鼠標移動事件
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <style scoped> .drag { border-radius:30px; position: relative; background-color: #75CDF9; width: 300px; height: 34px; margin-left: 30px; margin-top: 100px; line-height: 34px; text-align: center; } .handler { border-radius:30px; 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_bg { border-radius:30px; background-color: #13CE66; height: 34px; width: 0px; } .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; } </style> </head> <body> <div id="app"> <div class="drag" > <div class="drag_bg"></div> <div class="drag_text">{{confirmWords}}</div> <div @mousedown="mousedownFn($event)" class="handler handler_bg"></div> </div> </div> <script src="https://cdn.jsdelivr.net/npm/vue"></script> <script src="https://unpkg.com/element-ui/lib/index.js"></script> <script src="http://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script> <script> var vm = new Vue({ el: "#app", name: '', components: {}, props: {}, data() { return { beginClientX: 0, /*距離屏幕左端距離*/ mouseMoveStata: false, /*觸發(fā)拖動狀態(tài) 判斷*/ maxwidth: 258, /*拖動最大寬度,依據滑塊寬度算出來的*/ confirmWords: '拖動滑塊驗證', /*滑塊文字*/ confirmSuccess: false, /*驗證成功判斷*/ } }, created() {}, watch: { }, methods: { mousedownFn: function(e) { this.mouseMoveStata = true; this.beginClientX = e.clientX; }, //按下滑塊函數(shù) successFunction() { $(".handler").removeClass('handler_bg').addClass('handler_ok_bg'); this.confirmWords = '驗證通過' $(".drag").css({ 'color': '#fff' }); $(".drag").css({ 'background-color': '#13CE66' }); $(".handler").css({ 'left': this.maxwidth }); $(".drag_bg").css({ 'width': this.maxwidth }); $('body').unbind('mousemove'); $('body').unbind('mouseup'); this.confirmSuccess = true; } //驗證成功函數(shù) }, mounted() { $('body').on('mousemove', (e) => { //拖動,這里需要用箭頭函數(shù),不然this的指向不會是vue對象 if(this.mouseMoveStata) { var width = e.clientX - this.beginClientX; if(width > 0 && width <= this.maxwidth) { $(".handler").css({ 'left': width }); $(".drag_bg").css({ 'width': width }); } else if(width > this.maxwidth) { this.successFunction(); } } }); $('body').on('mouseup', (e) => { //鼠標放開 this.mouseMoveStata = false; var width = e.clientX - this.beginClientX; if(width < this.maxwidth) { $(".handler").css({ 'left': 0 }); $(".drag_bg").css({ 'width': 0 }); } }) } }); </script> </body> </html>
總結
以上所述是小編給大家介紹的Vue 實現(xiàn)拖動滑塊驗證功能(只有css+js沒有后臺驗證步驟),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
相關文章
vscode 配置vue+vetur+eslint+prettier自動格式化功能
這篇文章主要介紹了vscode 配置vue+vetur+eslint+prettier自動格式化功能,本文通過實例代碼圖文的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03深入探討Vue計算屬性與監(jiān)聽器的區(qū)別和用途
在Vue的開發(fā)中,計算屬性(Computed Properties)和監(jiān)聽器(Watchers)是兩種非常重要的概念,它們都用于響應式地處理數(shù)據變化,本文將帶你深入了解計算屬性和監(jiān)聽器的區(qū)別,以及在何時使用它們,感興趣的朋友可以參考下2023-09-09