vue3获取验证码+背景切换

需要安装element-plus组件库

用户获取验证码后按钮会被禁用,等待10秒后重新获取验证码

验证码

元素布局template部分

<template><div><el-button type="success" round :disabled="isSend" @click="countDown">{{ codeName }}</el-button></div>
</template>

script功能部分

<script setup>
import { ref, reactive, watch } from 'vue';
import { ElMessage } from 'element-plus'const isSend = ref(false); // 禁用
const codeName = ref("发送验证码");
const totalTime = 10; // 10秒倒计时
let timer = null; // 定时器
const code = ref() // 验证码存放处
const col = ref("") // 背景颜色rgb()const countDown = () => {if (isSend.value) return;isSend.value = true;codeName.value = `${totalTime}s后重新发送`;// 生成随机验证码const len = 6;const codeList = [];const chars = "ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz0123456789";const charsLen = chars.length;for (let i = 0; i < len; i++) {codeList.push(chars.charAt(Math.floor(Math.random() * charsLen)));}code.value = codeList.join("")console.log(codeList.join(""));ElMessage({message: '验证码提示---' + code.value,type: 'success',})// 倒计时let currentTime = totalTime;timer = setInterval(() => {currentTime--;codeName.value = `${currentTime}s后重新发送`;if (currentTime < 1) {clearInterval(timer);codeName.value = "重新发送验证码";isSend.value = false;}}, 1000);
};
</script>

样式这里没有

随机背景颜色

template部分

<template><div><div class="box"><h2>随机切换背景</h2></div></div>
</template>

script部分 

<script setup>
// 生成一个随机的颜色
const randomColor = () => {const r = Math.floor(Math.random() * (255 - 0) + 0);const g = Math.floor(Math.random() * (255 - 0) + 0);const b = Math.floor(Math.random() * (255 - 0) + 0);return "rgb(" + r + "," + g + "," + b + ")"
}const changecolor = () => {const box = document.querySelector('.box')const color = randomColor()box.style.backgroundColor = color
}
</script>

style部分

<style scoped>
.box {height: 100px;width: 200px;background-color: bisque;text-align: center;line-height: 100px;
}
</style>

完整代码:希望能帮助到你

<template><div><el-button type="success" round :disabled="isSend" @click="countDown">{{ codeName }}</el-button><div class="box"><h2>随机切换背景</h2></div></div>
</template><script setup>
import { ref, reactive, watch } from 'vue';
import { ElMessage } from 'element-plus'const isSend = ref(false); // 禁用
const codeName = ref("发送验证码");
const totalTime = 10; // 10秒倒计时
let timer = null; // 定时器
const code = ref() // 验证码存放处
const col = ref("") // 背景颜色rgb()const countDown = () => {if (isSend.value) return;isSend.value = true;codeName.value = `${totalTime}s后重新发送`;// 生成随机验证码const len = 6;const codeList = [];const chars = "ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz0123456789";const charsLen = chars.length;for (let i = 0; i < len; i++) {codeList.push(chars.charAt(Math.floor(Math.random() * charsLen)));}code.value = codeList.join("")console.log(codeList.join(""));ElMessage({message: '验证码提示---' + code.value,type: 'success',})ElMessage({message: '背景颜色提示---' + randomColor(),type: 'success',})changecolor()// 倒计时let currentTime = totalTime;timer = setInterval(() => {currentTime--;codeName.value = `${currentTime}s后重新发送`;if (currentTime < 1) {clearInterval(timer);codeName.value = "重新发送验证码";isSend.value = false;}}, 1000);
};// 生成一个随机的颜色
const randomColor = () => {const r = Math.floor(Math.random() * (255 - 0) + 0);const g = Math.floor(Math.random() * (255 - 0) + 0);const b = Math.floor(Math.random() * (255 - 0) + 0);return "rgb(" + r + "," + g + "," + b + ")"
}const changecolor = () => {const box = document.querySelector('.box')const color = randomColor()box.style.backgroundColor = color
}</script><style scoped>
.box {height: 100px;width: 200px;background-color: bisque;text-align: center;line-height: 100px;
}
</style>

效果展示:

加载中......

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/485955.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Leetcode--19. 删除链表的倒数第N个节点

给定一个链表&#xff0c;删除链表的倒数第 n 个节点&#xff0c;并且返回链表的头结点。 示例&#xff1a; 给定一个链表: 1->2->3->4->5, 和 n 2. 当删除了倒数第二个节点后&#xff0c;链表变为 1->2->3->5. 说明&#xff1a; 给定的 n 保证是有效…

python 几种常用测试框架

测试的常用规则 一个测试单元必须关注一个很小的功能函数&#xff0c;证明它是正确的&#xff1b;每个测试单元必须是完全独立的&#xff0c;必须能单独运行。这样意味着每一个测试方法必须重新加载数据&#xff0c;执行完毕后做一些清理工作。通常通过setUp()和setDown()方法处…

jdbc获取结果行数,如何获取JDBC中的行数?

Ive executed a JDBC query to obtain a resultset. Before iterating over it, Id like to quickly find out how many rows were returned. How can I do this with high performance?Im using Java 6, Oracle 11g, and the latest Oracle JDBC drivers.解决方案Youre going…

服务器系统盘最佳设置,启用系统的硬盘高级性能设置优化硬盘到最佳性能

硬盘性能直接关系到网吧机器的性能&#xff0c;如果是无盘服务器上的硬盘&#xff0c;那更是整个网吧的核心性能。所以一定要好好优化下&#xff0c;下面推荐一个小技巧吧&#xff1a;启用硬盘高级性能 \ 硬件管理器&#xff0c;选一个磁盘&#xff0c;右键属性&#xff0c;上…

ASML 1nm光刻机研究进展:摩尔定律尚未结束

文章来源&#xff1a;Sparrows NEWS、新智元摩尔定律的终点是什么&#xff1f;随着5nm光刻技术的大规模生产和3nm的突破&#xff0c;摩尔定律的终结变得越来越难以捉摸。可以肯定的是&#xff0c;随着过程的进一步改进&#xff0c;其成本将成倍增加。根据日本媒体Mynavi的报道&…

Leetcode--53. 最大子序和

给定一个整数数组 nums &#xff0c;找到一个具有最大和的连续子数组&#xff08;子数组最少包含一个元素&#xff09;&#xff0c;返回其最大和。 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4], 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大&#xff0c;为 6。 进阶: 如果你已经…

redis为什么选择单线程工作模型

1、先说一下为什么出现进程&#xff0c;线程 进程&#xff1a;在计算机发明之初就发现&#xff0c;在输入数据时&#xff08;I/O速度慢&#xff09;&#xff0c;CPU是空闲的&#xff0c;这样就浪费了CPU资源&#xff0c;为了充分利用CPU资源&#xff0c;发明了进程&#xff0c;…

js与c语言效率_JavaScript比c语言的性能差了多少?

我这里先不说和C之间的性能差距&#xff0c;而是展开说JavaScript递归优化问题&#xff0c;有人问我为什么不说性能差距&#xff0c;我&#xff1a;&#xff1f;&#xff1f;&#xff1f;这个问题就跟问地球为什么是圆的一样(明摆着)传统的递归函数&#xff0c;比如:function a…

服务器物理内存总是九十几,Solr总是使用超过90%的物理内存(Solr always use more than 90% of physical memory)...

Solr总是使用超过90&#xff05;的物理内存(Solr always use more than 90% of physical memory)我在solr索引中存储了300000个文档。 并使用4GB RAM作为solr服务器。 但它消耗超过90&#xff05;的物理内存。 所以我把我的数据转移到一台有16 GB RAM的新服务器上。 再次solr消…

​​《自然》2020年十大科学发现出炉:病毒,冷冻电镜与快速射电暴

来源&#xff1a;科研圈作者&#xff1a;陈梦圆、谢一璇、李姗珊、邱燕宁、魏潇科学成就

Http协议--Get和Post区别

1. 请求路径不同 post请求&#xff0c;在url后面不跟上任何的数据 Get请求&#xff0c;在地址后面跟上数据 2. 带上的数据不同&#xff0c;Post请求会使用流的方式写数据。 Get请求是在地址栏上跟数据 3. 由于Post请求使用流的方式写数据&#xff0c; 所以一定需要一个Con…

Hibernate中用到联合主键的使用方法,为何要序列化,为何要重写hashcode 和 equals 方法...

联合主键用Hibernate注解映射方式主要有三种&#xff1a; 第一、将联合主键的字段单独放在一个类中&#xff0c;该类需要实现java.io.Serializable接口并重写equals和hascode&#xff0c;再将该类注解为Embeddable,最后在主类中(该类不包含联合主键类中的字段)保存该联合主键类…

命令行设置dns_dos命令netsh图文教程,设置修改IP地址子网掩码网关命令行改dns...

大家好&#xff0c;我是老盖&#xff0c;首先感谢观看本文&#xff0c;本篇文章做的有视频&#xff0c;视频讲述的比较详细&#xff0c;也可以看我发布的视频。今天我们学习dos命令中的netsh&#xff0c;这个命令是网络命令&#xff0c;它有很多的功能&#xff0c;今天我们用它…

Leetcode--5081. 步进数

如果一个整数上的每一位数字与其相邻位上的数字的绝对差都是 1&#xff0c;那么这个数就是一个「步进数」。 例如&#xff0c;321 是一个步进数&#xff0c;而 421 不是。 给你两个整数&#xff0c;low 和 high&#xff0c;请你找出在 [low, high] 范围内的所有步进数&#x…

文件操作的基本流程

1、读模式 f.read()f.readable()#这个文件是否可读&#xff0c;返回布尔值&#xff1b;f.readline(“读模式”)#读取第一行&#xff1b;f.readlines(“读模式”)#读取所有内容 以字符串方式存储在列表内&#xff1b; f open(小重山,r,encodingutf-8) #第一个参数是文件位置&am…

第三代人工智能基础设施背后,是一次技术应用的常识普及运动

来源&#xff1a;脑极体买了新电脑和手机&#xff0c;你会提前安装好杀毒或安全软件&#xff0c;还是等被黑客攻破了才悔之晚矣&#xff1f;处理传染病疫情&#xff0c;是从源头释放药物和疫苗&#xff0c;还是坐等医院的患者超过治疗和处理能力&#xff1f;面对危机舆情&#…

5 ui自适应窗口_Qt编写地图综合应用5-自适应拉伸

一、前言用过echart的人都会遇到一个问题&#xff0c;就算是代码中写了window.onresize echart.resize&#xff0c;也只是横向自适应拉伸填充页面&#xff0c;垂直方向不会变化&#xff0c;除非指定高度才可以&#xff0c;这就比较郁闷了&#xff0c;为何echart本身不会自适应…

Leetcode--85. 最大矩形

给定一个仅包含 0 和 1 的二维二进制矩阵&#xff0c;找出只包含 1 的最大矩形&#xff0c;并返回其面积。 示例: 输入: [ ["1","0","1","0","0"], ["1","0","1","1","…

PowerDesigner生成sql语句时自动导出注释

1、为sql生成注释&#xff0c;操作如下&#xff0c;在其中选择Tools----》Excute commands-----》Edit/Run Script打开的窗口中添加以下信息 ****************************************************************************** * File: name2comment.vbs * Purpo…

为什么俄罗斯的数学那么牛?

编辑 ∑Gemini来源:奇趣数学苑但在国际上也有一个很著名的说法&#xff0c;就是世界上最好的大学&#xff0c;其实是“美国的学校&#xff0c;中国的学生&#xff0c;俄罗斯的教授”。俄罗斯数学家佩雷尔曼虽然俄罗斯现在相比以前来说&#xff0c;尤其明显的是在一些需要大量设…