Vue如何实现滑动验证功能


这篇文章主要介绍了Vue如何实现滑动验证功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

用Vue实现滑动验证码,鼠标点击滑动验证,验证成功之后会显示验证通过。

程序分析

1、鼠标的点击
2、滑块的拖动
3、未验证之前滑动条上显示的文字
4、滑块箭头指向Vue函数
5、判断是否拖动完毕
6、拖动完毕时改变背景色并显示验证成功

效果图演示

原始状态

点击之后拖动

拖动完毕

有没有感觉很奇妙的呢???

在欣赏代码之前准备工作要做好的!!!
**特别注意:**相关架包的引入(三个架包)

<script src="js/vue.js"></script><script src="https://unpkg/element-ui/lib/index.js"></script><script src="js/jquery.js"></script>

代码演示

<!DOCTYPE html><html>    <head>        <meta charset="UTF-8">        <title></title>        <script src="js/vue.js"></script>        <script src="https://unpkg/element-ui/lib/index.js"></script>        <script src="js/jquery.js"></script>        <style>            .big {                border-radius:30px;                position: relative;                background-color: #75CDF9;                width: 300px;                height: 34px;                margin-left: 30px;                margin-top: 100px;                line-height: 34px;                text-align: center;            }                        .hand {                border-radius:30px;                position: absolute;                top: 0px;                left: 0px;                width: 40px;                height: 32px;                border: 1px solid #ccc;                cursor: move;            }                        .handler {                background: #fff url("") no-repeat center;            }                        .handlerFinish {                background: #fff url("") no-repeat center;            }                        .bg {                border-radius:30px;                background-color: #13CE66;                height: 34px;                width: 0px;            }                        .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="big" >                <div class="bg"></div>                <div class="text">{{confirmWords}}</div>                <div @mousedown="mousedownFn($event)" class="hand handler"></div>            </div>        </div>                    </body>        <script>        var vm = new Vue({                el: "#app",            name: '',           &nbspponents: {},            props: {},            data() {                return {                    beginClientX: 0,                    mouseMoveStata: false,                    maxwidth: 258,                    confirmWords: '拖动滑块验证',                    /*滑块文字*/                    confirmSuccess: false, /*是否成功*/                }            },            created() {},            watch: {            },            methods: {                mousedownFn: function(e) {                    this.mouseMoveStata = true;                    this.beginClientX = e.clientX;                },                 //按下滑块                successFunction() {                    $(".hand").removeClass('handler').addClass('handlerFinish');                    this.confirmWords = '验证通过'                    $(".big").css({                        'color': '#fff'                    });                    $(".big").css({                        'background-color': '#13CE66'                    });                    $(".hand").css({                        'left': this.maxwidth                    });                    $(".bg").css({                        'width': this.maxwidth                    });                    $('body').unbind('mousemove');                    $('body').unbind('mouseup');                    this.confirmSuccess = true;                                    } //判断是否成功            },            mounted() {                $('body').on('mousemove', (e) => {                    //拖动使用箭头指向Vue函数                    if(this.mouseMoveStata) {                        var width = e.clientX - this.beginClientX;                        if(width > 0 && width <= this.maxwidth) {                            $(".hand").css({                                'left': width                            });                            $(".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) {                        $(".hand").css({                            'left': 0                        });                        $(".bg").css({                            'width': 0                        });                    }                })            }        });    </script></html>

感谢你能够认真阅读完这篇文章,希望小编分享的“Vue如何实现滑动验证功能”这篇文章对大家有帮助,同时也希望大家多多支持主机评测网,关注主机评测网行业资讯频道,更多相关知识等着你来学习!


上一篇:java?WebSocket?服务端如何实现

下一篇:javascript如何将值类型强制转为字符串


Copyright © 2002-2019 测速网 www.inhv.cn 皖ICP备2023010105号
测速城市 测速地区 测速街道 网速测试城市 网速测试地区 网速测试街道
温馨提示:部分文章图片数据来源与网络,仅供参考!版权归原作者所有,如有侵权请联系删除!

热门搜索 城市网站建设 地区网站制作 街道网页设计 大写数字 热点城市 热点地区 热点街道 热点时间 房贷计算器