当前位置: 首页 > news >正文

uniapp中uview组件丰富的Code 验证码输入框的使用方法

目录

基本使用

#自定义提示语

#保持倒计时

API

#Props

#Methods

#Event


基本使用

通过ref获取组件对象,再执行后面的操作,见下方示例。

  1. 通过seconds设置需要倒计的秒数(默认60)
  2. 通过ref调用组件内部的start方法,开始倒计时
  3. 通过监听change事件(从开始到结束之间,每秒触发一次)获得提示的文字,可能值如"获取验证码|12秒后重新获取|重新获取",可以自定义

注意:用户可能在倒计时的过程中点击获取验证码的按钮,组件内部提供了通过ref获取的canGetCode变量,在倒计时 过程中,该值为false,如果为false应该给予提示并不要再次向后端请求验证码,如果为true,则为获取验证码 之前,或者倒计结束之后,可以再次向后端请求验证码。

以下为完整示例,见如下:

<template><view class="wrap"><u-toast ref="uToast"></u-toast><u-code :seconds="seconds" @end="end" @start="start" ref="uCode" @change="codeChange"></u-code><u-button @tap="getCode">{{tips}}</u-button></view>
</template><script>export default {data() {return {tips: '',// refCode: null,seconds: 10,}},onReady() {// 注意这里不能将一个组件赋值给data的一个变量,否则在微信小程序会// 造成循环引用而报错,如果你想这样做,请在非data中定义refCode变量// this.refCode = this.$refs.uCode;},methods: {codeChange(text) {this.tips = text;},getCode() {if(this.$refs.uCode.canGetCode) {// 模拟向后端请求验证码uni.showLoading({title: '正在获取验证码'})setTimeout(() => {uni.hideLoading();// 这里此提示会被this.start()方法中的提示覆盖uni.$u.toast('验证码已发送');// 通知验证码组件内部开始倒计时this.$refs.uCode.start();}, 2000);} else {uni.$u.toast('倒计时结束后再发送');}},end() {uni.$u.toast('倒计时结束');},start() {uni.$u.toast('倒计时开始');}}}
</script><style lang="scss">.wrap {padding: 24rpx;}
</style>

#自定义提示语

组件内部有内置的提示语,如获取验证码前的提示语为"获取验证码",用户可以通过参数配置自定义的提示:

  • 获取前,参数为start-text,默认值为"获取验证码"
  • 倒计时期间,参数为change-text,默认为"X秒重新获取",这里的"x"(大小写均可),将会被倒计的秒数替代
  • 倒计时结束,参数为end-text,默认值为"重新获取"

#保持倒计时

一般情况下,在H5刷新浏览器,或者各端返回再进入时,倒计时会消失,导致用户可以再次尝试获取验证码,虽然后端还会对此进行进一步的判断。
对于这种情况,uView给出了一个keep-running参数(默认为false),为true的时候,即使刷新浏览器,或者返回上一个页面, 倒计时依然会继续(如果还在倒计时间内的话)。

注意: 如果您的一个页面或者多个页面同时使用了多个此组件,为了防止多个组件之间,保存在本地的多个继续倒计时的变量之间互相干扰,可以配置 各个组件的unique-key为一个不重复的字符串,以作区分:

/* A.vue */
<u-verification-code unique-key="page-a"></u-verification-code>/* B.vue */
<u-verification-code unique-key="page-b"></u-verification-code>

API

#Props

参数说明类型默认值可选值
seconds倒计时所需的秒数Number | String60-
startText开始前的提示语,见上方说明String获取验证码-
changeText倒计时期间的提示语,必须带有字母"x",见上方说明StringX秒重新获取-
endText倒计结束的提示语,见上方说明String重新获取-
keepRunning是否在H5刷新或各端返回再进入时继续倒计时Booleanfalsetrue
uniqueKey多个组件之间继续倒计时的区分key,见上方说明String--

#Methods

需要通过ref获取验证码组件才能调用,见上方"基本使用"说明

名称说明
start开始倒计时
reset结束当前正在进行中的倒计时,设置组件为可以重新获取验证码的状态

#Event

事件名说明回调参数版本
change倒计时期间,每秒触发一次text: 当前剩余多少秒的状态,见上方说明-
start开始倒计时触发--
end结束倒计时触发--
http://www.lryc.cn/news/271982.html

相关文章:

  • md文件图片上传方案:Github+PicGo 搭建图床
  • 从零开始 - 在Python中构建和训练生成对抗网络(GAN)模型
  • OfficeWeb365 Indexs 任意文件读取漏洞复现
  • Crypto的简单应用-前后端加密传输
  • Vue3-32-路由-重定向路由
  • 如何用js动态修改字体大小
  • 【BIG_FG_CSDN】C++ 数组与指针 (个人向——学习笔记)
  • 桌面天气预报软件 Weather Widget free mac特点介绍
  • HarmonyOS应用开发-搭建开发环境
  • <JavaEE> TCP 的通信机制(五) -- 延时应答、捎带应答、面向字节流
  • 电脑怎么设置代理IP上网?如何隐藏自己电脑的真实IP?
  • Django信号机制源码分析(观察者模式)
  • MyBatis-config.xml配置文件
  • 【Spring实战】17 REST服务介绍
  • java struts2教务管理系统Myeclipse开发mysql数据库struts2结构java编程计算机网页项目
  • 跟着cherno手搓游戏引擎【3】事件系统和预编译头文件
  • 排序算法之快速排序
  • Docker 从入门到实践:Docker介绍
  • 用IDEA创建/同步到gitee(码云)远程仓库(保姆级详细)
  • 【Linux】进程控制深度了解
  • kbdnso.dll文件缺失,软件或游戏报错的快速修复方法
  • Spring技术内幕笔记之IOC的实现
  • kotlin foreach 循环
  • 分享相关知识
  • RabbitMQ(七)ACK 消息确认机制
  • ubuntu 编译内核报错
  • Python之自然语言处理库snowNLP
  • C# 语法进阶 委托
  • 开源可观测性平台Signoz(四)【链路监控及数据库中间件监控篇】
  • 【嵌入式开发 Linux 常用命令系列 4.2 -- git .gitignore 使用详细介绍】