This article example shares the implementation of Vue slider validation. The code is as follows <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, /* Distance from the left end of the screen*/ mouseMoveStata: false, /* Trigger drag status judgment*/ maxwidth: '', /* Maximum drag width, calculated based on the slider width*/ confirmWords: 'Drag the slider to verify', /* Slider text*/ confirmSuccess: false /* Verification success judgment*/ } }, methods: { mousedownFn: function (e) { if (!this.confirmSuccess) { e.preventDefault && e.preventDefault() // Prevent browser default events such as text selection this.mouseMoveStata = true this.beginClientX = e.clientX } }, // mousedoen event successFunction () { this.confirmSuccess = true this.confirmWords = 'Verification passed' 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' }, // Verify success function mouseMoveFn (e) { if (this.mouseMoveStata) { 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() } } }, // mousemove event moseUpFn (e) { this.mouseMoveStata = 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' } } // mouseup event}, 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: 30%; height: 34px; line-height: 34px; text-align: center; } .handler { 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 { background-color: #7ac23c; height: 34px; width: 0px; } .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> The effect diagram is as follows The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM. You may also be interested in:
|
<<: Detailed explanation of how to create an updateable view in MySQL
>>: Using Nginx to implement grayscale release
<br />Structure and hierarchy reduce complex...
1. Understanding of transition attributes 1. The ...
After installing the MySQL database using the rpm...
Table of contents Thoughts triggered by an online...
1. Install and use Docer CE This article takes Ce...
MouseEvent When the mouse performs a certain oper...
Table of contents Preface 1. Binary Tree 1.1. Tra...
Copy code The code is as follows: <meta name=&...
Within rows, light border colors can be defined i...
Write at the beginning This article only covers E...
This article example shares the specific code of ...
I accidentally found that Vue.$set was invalid in...
To beautify the table, you can set different bord...
Table of contents 1 Install Docker 2 Configuring ...
For databases that have been running for a long t...