vue實(shí)現(xiàn)分割驗(yàn)證碼效果
本文實(shí)例為大家分享了vue實(shí)現(xiàn)分割驗(yàn)證碼效果的具體代碼,供大家參考,具體內(nèi)容如下
注:該代碼存在問(wèn)題,因?yàn)槲襪axlength =4 ,input 的寬度跟屏幕同寬,所以當(dāng)我input 里面的length == 4 的時(shí)候,我的光標(biāo)會(huì)超出屏幕,所以我在length == 4 的時(shí)候做了一個(gè)把光標(biāo)放到第三個(gè)的處理,這種雖用戶體驗(yàn)不好,也解了length==4的時(shí)候整個(gè)布局亂了的燃眉之急
上UI 圖

上代碼:
vue
<template>
? <div>
? ? <v-main class="bgi">
? ? ? <v-container class="verify">
? ? ? ? <v-icon @click="verifyShow = false" color="#000">mdi-close</v-icon>
? ? ? ? <div>
? ? ? ? ? <p class="verifyTitle">輸入驗(yàn)證碼</p>
? ? ? ? ? <p class="verifyTitle1" v-show="verifyStatus == 1">
? ? ? ? ? ? 驗(yàn)證碼已發(fā)送至 <span> {{ "+" + area + phone }}</span>
? ? ? ? ? </p>
? ? ? ? ? <p class="verifyTitle2" v-show="verifyStatus == 3">
? ? ? ? ? ? 驗(yàn)證碼不正確,請(qǐng)重新輸入
? ? ? ? ? </p>
? ? ? ? ? <div class="verifyInputBox">
? ? ? ? ? ? <div class="verifyInputBg verifyInputBg1"></div>
? ? ? ? ? ? <div class="verifyInputBg verifyInputBg2"></div>
? ? ? ? ? ? <div class="verifyInputBg verifyInputBg3"></div>
? ? ? ? ? ? <div class="verifyInputBg verifyInputBg4"></div>
? ? ? ? ? ? <input
? ? ? ? ? ? ? ref="verifyInput"
? ? ? ? ? ? ? type="text"
? ? ? ? ? ? ? class="verifyInput"
? ? ? ? ? ? ? maxlength="4"
? ? ? ? ? ? ? v-model="verifyInput"
? ? ? ? ? ? />
? ? ? ? ? </div>
? ? ? ? ? <v-btn
? ? ? ? ? ? :disabled="restTimeShow"
? ? ? ? ? ? outlined
? ? ? ? ? ? tile
? ? ? ? ? ? class="nextBtn"
? ? ? ? ? ? @click="verifyConfirm"
? ? ? ? ? >
? ? ? ? ? ? 確定
? ? ? ? ? </v-btn>
? ? ? ? ? <p class="restTime" v-show="restTimeShow">
? ? ? ? ? ? 重新獲取(<span>{{ restTime }}</span
? ? ? ? ? ? >s)
? ? ? ? ? </p>
? ? ? ? </div>
? ? ? </v-container>
? ? </v-main>
? </div>
</template>css
<style lang="scss" scoped>
.bgi {
? width: 100vw;
? height: 100vh;
? background: url("~@/assets/imgs/banner.png");
? background-size: 100% 100%;
? background-repeat: no-repeat;
? p {
? ? margin-bottom: 0;
? }
? .verify {
? ? width: 100%;
? ? height: 100%;
? ? position: relative;
? ? color: #000;
? ? background: #fff;
? ? .verifyTitle {
? ? ? margin-left: 2rem;
? ? ? margin-top: 3rem;
? ? ? font-size: 1.4rem;
? ? }
? ? .verifyTitle1 {
? ? ? margin-left: 2rem;
? ? ? margin-top: 0.6rem;
? ? ? font-size: 0.8125rem;
? ? ? span {
? ? ? ? color: #bfbfbf;
? ? ? }
? ? }
? ? .verifyTitle2 {
? ? ? margin-left: 2rem;
? ? ? margin-top: 0.6rem;
? ? ? font-size: 0.8125rem;
? ? ? color: #f53f3f;
? ? }
? ? input::-webkit-input-placeholder {
? ? ? color: #000;
? ? }
? ? .verifyInputBox {
? ? ? width: 20rem;
? ? ? margin: 3rem auto 0;
? ? ? position: relative;
? ? ? height: 4rem;
? ? ? z-index: 1;
? ? ? .verifyInputBg {
? ? ? ? position: absolute;
? ? ? ? z-index: 2;
? ? ? ? height: 4rem;
? ? ? ? width: 4rem;
? ? ? ? border-radius: 0.2rem;
? ? ? ? background: rgba($color: #000, $alpha: 0.1);
? ? ? }
? ? ? .verifyInputBg2 {
? ? ? ? left: 5.33rem;
? ? ? }
? ? ? .verifyInputBg3 {
? ? ? ? left: 10.66rem;
? ? ? }
? ? ? .verifyInputBg4 {
? ? ? ? left: 16rem;
? ? ? }
? ? ? .verifyInput {
? ? ? ? height: 4rem;
? ? ? ? line-height: 4rem;
? ? ? ? width: 100%;
? ? ? ? letter-spacing: 4.53rem;
? ? ? ? padding-left: 1.5rem;
? ? ? ? font-size: 1.4rem;
? ? ? ? font-weight: 700;
? ? ? ? position: absolute;
? ? ? ? z-index: 3;
? ? ? }
? ? }
? ? .restTime {
? ? ? margin-top: 1rem;
? ? ? color: #bfbfbf;
? ? ? font-size: 0.8125rem;
? ? ? text-align: center;
? ? }
? }
? .nextBtn {
? ? margin-top: 2rem;
? ? margin-left: 2rem;
? ? width: calc(100% - 4rem);
? ? height: 3rem !important;
? ? background: #ff962b;
? ? border-radius: 0.3125rem;
? ? font-size: 1rem;
? ? color: #ffffff !important;
? ? border: none;
? }
? .nextBtn:disabled {
? ? background: #d2d2d2;
? ? color: #ffffff !important;
? }
}
</style>script
<script>
export default {
? name: "Login",
? data() {
? ? return {
? ? ? area: "86",
? ? ? phone: "",
? ? ? verifyInput: "",
? ? ? verifyStatus: "1", // 1 ?-- 驗(yàn)證碼發(fā)送至 ?|| ?2 --正在驗(yàn)證驗(yàn)證碼 ?|| 3 -- 驗(yàn)證碼錯(cuò)誤
? ? ? restTimer: null,
? ? ? restTime: 60,
? ? ? restTimeShow: false,
? ? };
? },
? watch: {
? ? verifyInput(newVal) {
? ? ? if (newVal.length == 4) {
? ? ? ? this.$nextTick(() => {
? ? ? ? ? let verifyInput = this.$refs.verifyInput;
? ? ? ? ? verifyInput.setSelectionRange(3,3);
? ? ? ? });
? ? ? ? this.verifyConfirm();
? ? ? }
? ? },
? },
? methods: {
? ? verifyConfirm() {
? ? ? this.restTimeShow = true;
? ? ? this.verifyStatus = 2;
? ? ? this.restTimeFun();
? ? },
? ? restTimeFun() {
? ? ? if (!this.restTimer) {
? ? ? ? this.restTime = 60;
? ? ? ? this.restTimer = setInterval(() => {
? ? ? ? ? if (this.restTime > 0) {
? ? ? ? ? ? this.restTime--;
? ? ? ? ? } else {
? ? ? ? ? ? this.restTimeShow = false;
? ? ? ? ? ? clearInterval(this.restTimer);
? ? ? ? ? ? this.restTimer = null;
? ? ? ? ? }
? ? ? ? }, 1000);
? ? ? }
? ? },
? },
};
</script>效果圖:


以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue CLI項(xiàng)目 axios模塊前后端交互的使用(類似ajax提交)
這篇文章主要介紹了Vue-CLI項(xiàng)目-axios模塊前后端交互的使用詳解(類似ajax提交),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09
Vue Axios異步與數(shù)據(jù)類型轉(zhuǎn)換問(wèn)題淺析
總的來(lái)說(shuō)這并不是一道難題,那為什么要拿出這道題介紹?拿出這道題真正想要傳達(dá)的是解題的思路,以及不斷優(yōu)化探尋最優(yōu)解的過(guò)程。希望通過(guò)這道題能給你帶來(lái)一種解題優(yōu)化的思路,Axios是一個(gè)開(kāi)源的可以用在瀏覽器端和Node JS的異步通信框架,主要作用就是實(shí)現(xiàn)AJAX異步通信2023-01-01
Vue實(shí)現(xiàn)按鈕級(jí)權(quán)限方案
這篇文章主要介紹了Vue按鈕級(jí)權(quán)限方案,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-11-11
vue3使用vuedraggable和grid實(shí)現(xiàn)自定義拖拽布局方式
這篇文章主要介紹了vue3使用vuedraggable和grid實(shí)現(xiàn)自定義拖拽布局方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
前端elementUI?select選擇器實(shí)現(xiàn)遠(yuǎn)程搜索
這篇文章主要為大家介紹了前端使用elementUI?select選擇器實(shí)現(xiàn)遠(yuǎn)程搜索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
使用 Vue-TCB 快速在 Vue 應(yīng)用中接入云開(kāi)發(fā)的方法
這篇文章主要介紹了如何使用 Vue-TCB 快速在 Vue 應(yīng)用中接入云開(kāi)發(fā),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02
vue項(xiàng)目檢測(cè)依賴包是否有使用的問(wèn)題
這篇文章主要介紹了vue項(xiàng)目檢測(cè)依賴包是否有使用的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
Vue實(shí)現(xiàn)購(gòu)物車場(chǎng)景下的應(yīng)用
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)購(gòu)物車場(chǎng)景下的應(yīng)用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11

