Vue3滑動(dòng)到最右驗(yàn)證功能實(shí)現(xiàn)
1、思路
1、在登錄頁(yè)面需要啟動(dòng)向右滑塊驗(yàn)證
2、效果圖

3、文章地址:滑動(dòng)驗(yàn)證碼的實(shí)現(xiàn)-vue-simple-verify
2、成分分析
1、由三塊構(gòu)成,分別是底部條、拖動(dòng)條、拖動(dòng)移動(dòng)部分
2、底部條:整體容器,包括背景、邊框和文字(請(qǐng)按住滑塊,拖動(dòng)到最右邊)
3、拖動(dòng)條:圖片+邊框+背景色即可
4、完成部分:背景、邊框和文字(驗(yàn)證完成)
3、事件分析
1、鼠標(biāo)按下事件:記錄鼠標(biāo)位置以及狀態(tài)
2、鼠標(biāo)移動(dòng)事件:計(jì)算滑塊位置
3、鼠標(biāo)離開(kāi)事件:更新?tīng)顟B(tài)至初始狀態(tài)
4、鼠標(biāo)抬起事件:更新?tīng)顟B(tài)至初始狀態(tài)
4、效果圖

5、代碼
1、SlideVerify.vue文件
<template>
<div
ref="sliderContainer"
@mousemove="onMouseMove"
@mouseup="onMouseUp"
class="slider-verify-container"
@mouseleave="onMouseLeave"
>
<span v-if="blockState === 0">請(qǐng)按住滑塊,拖動(dòng)到最右邊</span>
<div
@mousedown="onMouseDown"
:style="{ left: leftP }"
class="slider-verify-block"
/>
<div :style="{ width: leftP }" class="slider-verify-complete">
<span v-if="blockState === 2">驗(yàn)證成功</span>
</div>
</div>
</template>
<script setup>
import { ref, defineEmits } from "vue";
const emit = defineEmits(["success", "failed"]);
const leftP = ref("0");
const blockState = ref(0);
const startP = ref(undefined);
const sliderContainer = ref(undefined);
const onMouseDown = (e) => {
if (blockState.value !== 2) {
leftP.value = "0";
blockState.value = 1;
startP.value = {
clientX: e.clientX,
};
} else {
leftP.value = "0";
blockState.value = 0;
}
};
const onMouseMove = (e) => {
if (blockState.value === 1) {
let width = e.clientX - startP.value.clientX;
if (width + 56 > 400) {
leftP.value = 400 - 56 + "px";
blockState.value = 2;
emit("success");
} else {
leftP.value = width + "px";
}
}
};
const onMouseUp = (e) => {
if (blockState.value !== 2) {
leftP.value = "0";
blockState.value = 0;
emit("failed");
}
};
const onMouseLeave = (e) => {
if (blockState.value !== 2) {
leftP.value = "0";
blockState.value = 0;
emit("failed");
}
};
</script>
<style lang="scss" scoped>
.slider-verify-container {
width: 100%;
height: 56px;
background-color: transparent;
position: relative;
border: solid 1px #20cccf;
text-align: center;
color: #20cccf;
line-height: 56px;
user-select: none;
-moz-user-select: none;
-ms-user-select: none;
-webkit-user-select: none;
}
.slider-verify-complete {
width: 0;
height: 56px;
position: absolute;
background-color: #00e6f14f;
left: 0;
top: 0;
}
.slider-verify-block {
width: 56px;
height: 56px;
background-image: url("@/assets/images/login6/arrow.png");
background-color: white;
position: absolute;
left: 0;
top: -1px;
border: solid 1px #20cccf;
background-size: 50%;
background-repeat: no-repeat;
background-position: center;
}
</style>2、調(diào)用代碼
<slide-verify @success="onVerifySuccess" @failed="onVerifyFailed" />
到此這篇關(guān)于Vue3滑動(dòng)到最右驗(yàn)證功能的文章就介紹到這了,更多相關(guān)Vue3滑動(dòng)到最右驗(yàn)證內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
安裝vue無(wú)法運(yùn)行、此系統(tǒng)無(wú)法運(yùn)行腳本問(wèn)題及解決
這篇文章主要介紹了安裝vue無(wú)法運(yùn)行、此系統(tǒng)無(wú)法運(yùn)行腳本問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
vue實(shí)現(xiàn)的網(wǎng)易云音樂(lè)在線播放和下載功能案例
這篇文章主要介紹了vue實(shí)現(xiàn)的網(wǎng)易云音樂(lè)在線播放和下載功能,結(jié)合具體實(shí)例形式分析了網(wǎng)易云音樂(lè)相關(guān)接口調(diào)用與操作技巧,需要的朋友可以參考下2019-02-02
Vue3處理大數(shù)據(jù)量渲染和優(yōu)化的方法小結(jié)
在現(xiàn)代Web應(yīng)用中,隨著用戶數(shù)據(jù)和交互的復(fù)雜性增加,如何高效地處理大數(shù)據(jù)量渲染成為了前端開(kāi)發(fā)的重要環(huán)節(jié),本文將以Vue 3為例,探討如何優(yōu)化大數(shù)據(jù)量渲染,提升應(yīng)用性能,需要的朋友可以參考下2024-07-07
Vue檢測(cè)屏幕變化來(lái)改變不同的charts樣式實(shí)例
這篇文章主要介紹了Vue檢測(cè)屏幕變化來(lái)改變不同的charts樣式實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10
Vue3實(shí)現(xiàn)全局loading指令的示例詳解
這篇文章主要介紹了Vue3實(shí)現(xiàn)全局loading指令,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06
vue-router解決相同路徑跳轉(zhuǎn)報(bào)錯(cuò)的問(wèn)題
這篇文章主要介紹了vue-router解決相同路徑跳轉(zhuǎn)報(bào)錯(cuò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04
vue3開(kāi)啟攝像頭并進(jìn)行拍照的實(shí)現(xiàn)示例
本文主要介紹了vue3開(kāi)啟攝像頭并進(jìn)行拍照的實(shí)現(xiàn)示例,主要是使用navigator.mediaDevices.getUserMedia這個(gè)API來(lái)實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01
vue解決花括號(hào)數(shù)據(jù)綁定不成功的問(wèn)題
今天小編就為大家分享一篇vue解決花括號(hào)數(shù)據(jù)綁定不成功的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10
element中el-cascader級(jí)聯(lián)選擇器只有最后一級(jí)可以多選
本文主要介紹了element中el-cascader級(jí)聯(lián)選擇器只有最后一級(jí)可以多選,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-01-01

