vue實現滑塊滑動校驗
阿新 • • 發佈:2019-02-16
down -c 防止 rep elements error handler pbm UNC 為了防止機器操作自動提交,我們需要添加滑動校驗。
實現代碼如下:
1.子組件slider.vue
<template> <div class="drag" ref="dragDiv"> <div class="drag_bg"></div> <div class="drag_text">{{confirmWords}}</div> <div ref="moveDiv" @mousedown="mouseDownFn($event)" :class="{‘handler_ok_bg‘:confirmSuccess}"class="handler handler_bg" style="position: absolute;top: 0px;left: 0px;"></div> </div> </template> <script> export default { data(){ return { beginClientX: 0, /*距離屏幕左端距離*/ mouseMoveState: false, /*觸發拖動狀態 判斷*/ maxWidth: ‘‘, /*拖動最大寬度,依據滑塊寬度算出來的*/ confirmWords: ‘向右拖動滑塊驗證‘, /*滑塊文字*/ confirmSuccess: false /*驗證成功判斷*/ } }, methods: { //mousedown 事件 mouseDownFn:function (e) { if(!this.confirmSuccess){ e.preventDefault && e.preventDefault(); //阻止文字選中等 瀏覽器默認事件 this.mouseMoveState = true; this.beginClientX = e.clientX; } }, //驗證成功函數 successFunction(){ this.confirmSuccess = true; this.confirmWords = ‘驗證通過‘; if(window.addEventListener){ document.getElementsByTagName(‘html‘)[0].removeEventListener(‘mousemove‘,this.mouseMoveFn); document.getElementsByTagName(‘html‘)[0].removeEventListener(‘mouseup‘,this.moseUpFn); }else { document.getElementsByTagName(‘html‘)[0].removeEventListener(‘mouseup‘,()=>{}); } document.getElementsByClassName(‘drag_text‘)[0].style.color = ‘#fff‘; document.getElementsByClassName(‘handler‘)[0].style.left = this.maxWidth + ‘px‘; document.getElementsByClassName(‘drag_bg‘)[0].style.width = this.maxWidth + ‘px‘; }, //mousemove事件 mouseMoveFn(e){ if(this.mouseMoveState){ let width = e.clientX - this.beginClientX; if(width>0 && width<=this.maxWidth){ document.getElementsByClassName(‘handler‘)[0].style.left = width + ‘px‘; document.getElementsByClassName(‘drag_bg‘)[0].style.width = width + ‘px‘; }else if(width>this.maxWidth){ this.successFunction(); } } }, //mouseup事件 moseUpFn(e){ this.mouseMoveState = false; var width = e.clientX - this.beginClientX; if(width<this.maxWidth){ document.getElementsByClassName(‘handler‘)[0].style.left = 0 + ‘px‘; document.getElementsByClassName(‘drag_bg‘)[0].style.width = 0 + ‘px‘; } } }, mounted(){ this.maxWidth = this.$refs.dragDiv.clientWidth - this.$refs.moveDiv.clientWidth; document.getElementsByTagName(‘html‘)[0].addEventListener(‘mousemove‘,this.mouseMoveFn); document.getElementsByTagName(‘html‘)[0].addEventListener(‘mouseup‘,this.moseUpFn) } } </script> <style scoped> .drag{ position: relative; background-color: #e8e8e8; width: 100%; height: 40px; line-height: 40px; text-align: center; border: 1px solid #ccc; border-radius: 4px; } .handler{ width: 40px; height: 38px; border: 1px solid #ccc; border-radius: 4px; cursor: move; } .handler_bg{ background: #fff url("") no-repeat center; } .handler_ok_bg{ border-top-left-radius: 0; border-bottom-left-radius: 0; background: #fff url("") no-repeat center; } .drag_bg{ background-color: #7ac23c; height: 38px; width: 0px; border-radius: 4px 0 0 4px; } .drag_text{ position: absolute; top: 0px; width: 100%;text-align: center; -moz-user-select: none; -webkit-user-select: none; user-select: none; -o-user-select:none; -ms-user-select:none; } </style>
2.調用組件:(使用了ElementUI)
<template> <el-form class="form-wrapper" ref="myForm" :model="myForm" label-width="110px"> <el-form-item label="滑塊驗證:"> <div><slider ref="slider"></slider></div> </el-form-item> <el-form-item> <el-button type="primary" @click="toSubmit">提交</el-button> </el-form-item> </el-form> </template> <script type="text/ecmascript-6"> import slider from ‘./slider‘ export default { data() { return { myForm: {} } }, components: { slider }, methods: { toSubmit() { if(this.$refs[‘slider‘]) { // 未通過驗證時,提示錯誤信息並返回 if (!this.$refs[‘slider‘].confirmSuccess) { this.$message.error("請拖動滑塊驗證"); return } } // 通過驗證後提交 // TO DO ... this.$message.success("驗證成功,可提交"); }, } } </script> <style type="text/css" scoped> .form-wrapper { margin-top: 50px; width: 500px; } </style>
3.效果圖:
vue實現滑塊滑動校驗