欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue實現(xiàn)滑塊拖拽校驗功能的全過程

 更新時間:2021年08月04日 14:53:58   作者:何小玍  
vue驗證滑塊功能,在生活中很多地方都可以見到,使用起來非常方便,這篇文章主要給大家介紹了關(guān)于vue實現(xiàn)滑塊拖拽校驗功能的相關(guān)資料,需要的朋友可以參考下

效果圖

定義骨架,寫html和css

html部分

<template>
    <div class="drag-wrapper" ref="dragDiv">
        <div class="drag_bg"></div>
        <div class="drag_text f14">{{ confirmWords }}</div>
        <!-- 移動的模塊 -->
        <div ref="moveDiv"
             @mousedown="mousedownFn($event)"
             :class="{'handler_ok_bg': confirmSuccess}"
             class="handler handler_bg"></div>
    </div>
</template>

css部分: 由于擔心圖片源的問題,所以寫成了base64的圖片

<style scoped>
    .drag{
        position: relative;
        background-color: #e8e8e8;
        width: 100%;
        height: 40px;
        line-height: 40px;
        text-align: center;
    }
    .handler{
        width: 40px;
        height: 40px;
        border: 1px solid #ccc;
        cursor: move;
        position: absolute;top: 0px;left: 0px;
    }
    .handler_bg{
        background: #fff url("") no-repeat center;
    }
    .handler_ok_bg{
        background: #fff url("") no-repeat center;
    }
    .drag_bg{
        background-color: #7ac23c;
        height: 40px;
        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>

實現(xiàn)滑動拖拽校驗

定義參數(shù)

data() {
    return {
        beginClientX:0,               // 距離屏幕左端距離
        mouseMoveStata:false,         // 觸發(fā)拖動狀態(tài)  判斷
        maxwidth:'',                  // 拖動最大寬度,依據(jù)滑塊寬度算出來的
        confirmWords:'拖動滑塊驗證',   // 滑塊文字
        confirmSuccess:false          // 驗證成功判斷
    }
}

1. 在mounted里面,根據(jù)滑塊寬度計算可拖動最大寬度以及監(jiān)聽手指的觸摸和離開事件

mounted() {
    // 根據(jù)滑塊寬度計算可拖動最大寬度
    this.maxwidth = this.$refs.dragDiv.clientWidth - this.$refs.moveDiv.clientWidth
    // 監(jiān)聽手指的觸摸事件
    document.getElementsByTagName('html')[0].addEventListener('mousemove', this.mouseMoveFn)
    // 監(jiān)聽手指離開事件
    document.getElementsByTagName('html')[0].addEventListener('mouseup', this.moseUpFn)
}

2. 編寫手指滑動的事件和手指離開的事件

mousemove事件

首先判斷是否觸發(fā)拖動狀態(tài),然后計算拖動的距離和模塊距離,實時賦值

//驗證成功函數(shù)
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()
    }
},

mouseup事件

把拖動狀態(tài)改成false,并且把滑塊移到對應的手指落下位置上

moseUpFn(e) {
    this.mouseMoveState = !1                        // 修改狀態(tài)
    const 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'
    }
}

在上面html部分的handler塊里,定義了mousedown事件(mousedownFn($event))

需要阻止文件選中等瀏覽器默認行為,并把觸發(fā)拖動狀態(tài)這個閾值打開,記錄手指移動的距離

mousedownFn:function (e) {
    e.preventDefault && e.preventDefault()   // 阻止文字選中等 瀏覽器默認事件
    this.mouseMoveStata = true               // 把觸發(fā)拖動狀態(tài)這個閾值打開
    this.beginClientX = e.clientX            // 記錄手指移動的距離
},

至此,功能就完成了。。

完整的JS代碼如下

<script>
    export default {
        data(){
            return {
                beginClientX:0,           /*距離屏幕左端距離*/
                mouseMoveStata:false,     /*觸發(fā)拖動狀態(tài)  判斷*/
                maxwidth:'',               /*拖動最大寬度,依據(jù)滑塊寬度算出來的*/
                confirmWords:'拖動滑塊驗證',   /*滑塊文字*/
                confirmSuccess:false           /*驗證成功判斷*/
            }
        },
        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)
        },
        methods: {
            mousedownFn:function (e) {
                if(!this.confirmSuccess){
                    e.preventDefault && e.preventDefault()   //阻止文字選中等 瀏覽器默認事件
                    this.mouseMoveStata = true
                    this.beginClientX = e.clientX
                }
            },
            //mousedoen 事件
            successFunction(){
                this.confirmSuccess = true
                this.confirmWords = '驗證通過'
                this.$emit('onValidation', true)
                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'
            },
            //驗證成功函數(shù)
            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事件
            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'
                }
            }
        }
    }
</script>

總結(jié)

到此這篇關(guān)于vue實現(xiàn)滑塊拖拽校驗功能的文章就介紹到這了,更多相關(guān)vue滑塊拖拽校驗內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 如何利用VUE創(chuàng)建視頻流應用

    如何利用VUE創(chuàng)建視頻流應用

    這篇文章主要給大家介紹了關(guān)于如何利用VUE創(chuàng)建視頻流應用的相關(guān)資料,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2022-03-03
  • vue基于elementUI表格狀態(tài)判斷展示方式

    vue基于elementUI表格狀態(tài)判斷展示方式

    這篇文章主要介紹了vue基于elementUI表格狀態(tài)判斷展示方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • antd vue v-decorator的取值與賦值問題

    antd vue v-decorator的取值與賦值問題

    這篇文章主要介紹了antd vue v-decorator的取值與賦值問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Vue中forEach()的使用方法例子

    Vue中forEach()的使用方法例子

    這篇文章主要給大家介紹了關(guān)于Vue中forEach()使用方法的相關(guān)資料,forEach和map是數(shù)組的兩個方法,作用都是遍歷數(shù)組,在vue項目的處理數(shù)據(jù)中經(jīng)常會用到,需要的朋友可以參考下
    2023-09-09
  • 寫一個Vue loading 插件

    寫一個Vue loading 插件

    這篇文章主要介紹了如何寫一個Vue loading 插件,幫助大家更好的理解和學習vue 插件的相關(guān)知識,感興趣的朋友可以了解下
    2020-11-11
  • vue實現(xiàn)百度語音合成的實例講解

    vue實現(xiàn)百度語音合成的實例講解

    在本篇文章里小編給大家整理的是關(guān)于vue實現(xiàn)百度語音合成的實例內(nèi)容,以及相關(guān)代碼,需要的朋友們參考下。
    2019-10-10
  • vue攔截器及請求封裝代碼

    vue攔截器及請求封裝代碼

    這篇文章主要介紹了vue攔截器及請求封裝代碼,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • 解決Antd Table表頭加Icon和氣泡提示的坑

    解決Antd Table表頭加Icon和氣泡提示的坑

    這篇文章主要介紹了解決Antd Table表頭加Icon和氣泡提示的坑,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 使用vue 國際化i18n 實現(xiàn)多實現(xiàn)語言切換功能

    使用vue 國際化i18n 實現(xiàn)多實現(xiàn)語言切換功能

    這篇文章主要介紹了使用vue 國際化i18n 多實現(xiàn)語言切換功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2018-10-10
  • vue打包后,用后端接口報錯304、404問題

    vue打包后,用后端接口報錯304、404問題

    這篇文章主要介紹了vue打包后,用后端接口報錯304、404問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05

最新評論