微信小程序---实现输入手机验证码功能

*** html部分

<view class='container'>

  <view class='main-title' bindtap="test">

    输入短信验证码

  </view>

  <view class="sub-title">

    已向<text class="phone">139****9999</text>发送验证码

  </view>

  <view class="code-box" bindtap="getFocus">

    <view class="{{code.length==0?'active':'input-box'}}">{{code[0]}}</view>

    <view class="{{code.length==1?'active':'input-box'}}">{{code[1]}}</view>

    <view class="{{code.length==2?'active':'input-box'}}">{{code[2]}}</view>

    <view class="{{code.length==3?'active':'input-box'}}">{{code[3]}}</view>

    <view class="{{code.length==4?'active':'input-box'}}">{{code[4]}}</view>

    <view class="{{code.length==5?'active':'input-box'}}">{{code[5]}}</view>

  </view>

  <input bindinput="getCode"  class="input-number" type="number" focus="{{isFocus}}" maxlength="6" />

  <view class="time-box">

    <view class="regain" hover-class="btn-hover" wx:if="{{isRegain}}" bindtap="regain">重新获取验证码</view>

    <view class="regain-info" wx:else>

      <text class="time">{{time}}</text>后可重新获取短信

    </view>

  </view>

 *** css部分

page{

  width: 100%;

  height: 100%;

  overflow: hidden;

}

.container{

  padding-top: 260rpx;

  width: 100%;

  height: 100%;

  background-color: #fafafa;

}

.container .main-title{

  font-size: 40rpx;

  color: #333;

  text-align: center;

  font-weight: bold;

  margin-bottom: 20rpx;

}

.container .sub-title{

  font-size: 30rpx;

  color: #666;

  text-align: center;  

}

.container .sub-title .phone{

  font-size: 30rpx;

  color: #333;

  font-weight: bold;

}

.container .code-box{

  width: 510rpx;

  height: 80rpx;

  margin-left: auto;

  margin-right: auto;

  display: flex;

  justify-content: space-between;

  margin-top: 80rpx;

}

.container .code-box .input-box{

  height: 80rpx;

  width: 72rpx;

  box-sizing: border-box;

  border: solid 1rpx #d7d7d7;

  text-align: center;

  line-height: 80rpx;

  color: #333;

  font-size: 34rpx;

}

.container .code-box .active{

  height: 80rpx;

  width: 72rpx;

  box-sizing: border-box;

  border: solid 1rpx #d7d7d7;

  text-align: center;

  line-height: 80rpx;

  color: #333;

  font-size: 34rpx;

  border-color: #3399cc;

.container .input-number{

  opacity: 0;

  position: absolute;

  z-index: -1;

  height: 0rpx;

  width: 0rpx;

}

.container .time-box{

  margin-top: 150rpx;

  text-align: center;

  font-size: 30rpx;

}

.container .time-box .regain{

  color: #3399cc;  

}

.container .time-box .regain-info{

  color: #b5b5b5;

}

*** js部分

data: {

    isFocus:true,

    code: "",

    isRegain:false,

    timer:null,

    time:20,

  },

   /* 生命周期函数--监听页面加载 */

  onLoad: function (options) {

    this.countdown();

  },

  regain(){

    this.setData({

      isRegain: false,

    });  

    this.countdown();  

  },

  getFocus(){

    this.setData({

      isFocus: true,

    });

  },

  getCode(e){

    console.log(e)

    this.setData({

      code: e.detail.value

    });

  },

  countdown(){

    var currentTime = this.data.time

    let timer=setInterval(()=>{

      currentTime--;

      this.setData({

        time: currentTime

      })

      if (currentTime <= 0) {

        clearInterval(timer)

        this.setData({

          time: 20,

          isRegain:true,

        })

      }      

    },1000)

  },

})

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

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

相关文章

Docker Harbor 2.3.4 集群 双主复制高可用镜像仓库

下面操作大部分是双节点同时执行一样的命令&#xff0c;不同的地方我会进行标注和特殊说明 文章目录一、环境准备1. 环境要求2. 节点总览3. 安装docker-compose二、安装harbor2.1. 下载2.2. 解压2.3. 调整配置2.4. 安装 harbor2.5. 效果验证三、Docker开启远程API3.1. 修改配置…

如何用Chrome读懂网站监测Cookie

作者 | 朱顺意责编 | 李雪敬出品 | CSDN云计算&#xff08;ID&#xff1a;CSDNcloud&#xff09;网站监测工具用于标识用户的 Cookie 分为第1方 Cookie 和第3方 Cookie&#xff0c;这两者本质上没有什么区别&#xff0c;只是身份不同。Cookie 有 Domain 属性&#xff0c;当 Coo…

DataWorks百问百答01:数据同步该用什么资源组

引子 很多用户在使用数据集成建立同步任务时&#xff0c;往往都会困惑一个设置&#xff0c;即“资源组设置”。 大家常有的疑问是“资源组是用来做什么的&#xff1f;跟网络之间什么关系&#xff1f;我该选择那种资源组&#xff1f;” 下面本文给您一个简要的介绍。 什么是资源…

在阿里,40岁的奋斗姿势

在阿里&#xff0c;40岁的奋斗姿势 在阿里&#xff0c;什么样的年纪可以称为老呢&#xff1f;35岁&#xff1f; 在云网络&#xff0c;有这样一群人&#xff0c;他们的平均年龄接近40&#xff0c;却刚刚开辟职业生涯的第二战场。 他们的奋斗姿势是什么样的呢&#xff1f; 洛神…

nginx配置多个conf文件

今天整理了下&#xff0c;在centos 7.6 系统下怎么配置多个conf文件。 step 1:在nginx.conf文件所在目录新建conf.d目录&#xff0c;即mkdir conf.d&#xff0c;为确保权限能够访问到 chmod 777 conf.dstep 2:编辑nginx.conf文件&#xff0c;内容为&#xff1a; #user nobody…

CPU有个禁区,内核权限也无法进入!

来源 | 编程技术宇宙封图 | CSDN 下载自视觉中国神秘项目我是CPU一号车间的阿Q&#xff0c;是的&#xff0c;我又来了。最近一段时间&#xff0c;我几次下班约隔壁二号车间虎子&#xff0c;他都推脱没有时间&#xff0c;不过也没看见他在忙个啥。前几天&#xff0c;我又去找他&…

Vue---淘宝镜像cnpm---安装vue-cli

1. 淘宝镜像命令 npm install -g cnpm --registryhttps://registry.npm.taobao.org 2. 安装vue-cli脚手架 npm install -g vue/cli 3.vue-cli脚手架更新 npm i -g vue/cli 4. 查看当前vue-cli版本号 vue -V

防删库实用指南 | 只需一步,快速召回被误删的表

数据库的一些非常不错的企业级功能都是“养兵千日&#xff0c;用兵一时”&#xff0c;比如Oracle 10g中的回收站&#xff08;Recycle Bin&#xff09;功能&#xff0c;可以在特殊情况下发挥特种兵的功能&#xff0c;比如当你删除一个表空间、一个用户&#xff08;Schema)时&…

智能化中的控制与自动化中的控制不同

智能化中的控制相对于自动化中的控制更加灵活、智能、综合和学习能力强。智能化控制系统能够根据实际情况进行自主决策和优化&#xff0c;适用范围更广&#xff0c;效果更好。 首先&#xff0c;智能化控制系统能够根据外部环境的变化和实时数据的反馈来自主调整和优化控制策略&…

Flink on Zeppelin (4) - 机器学习篇

今天我来讲下如何在 Zeppelin 里做机器学习。机器学习的重要性我就不多说了&#xff0c;我们直奔主题。 Flink 在机器学习这个领域发力较晚&#xff0c;社区版没有一个完整的机器学习算法库可以用&#xff0c;Alink[1]是目前 Flink 生态圈相对比较完整的机器学习算法库&#x…

docker yum 安装

文章目录一、安装docker1. 卸载旧版本2. 需要的安装包3. 设置镜像仓库4. yum更新软件包索引5. 安装docker-ce6. 启动docker7. 查看版本二、卸载docker2.1. 卸载docker2.2. 删除docker资源三、指定版本安装docker一、安装docker https://docs.docker.com/engine/install/centos…

解决Vue3创建项目后的Error: Cannot find module ‘vue-loader-v16/package.json‘问题

1. 卸载vue-loader-v16依赖 npm uninstall vue-loader-v16 2.使用cnpm安装vue-loader-v16依赖 cnpm i vue-loader-v16 最后npm run serve 重新启动项目

五个问答,告诉你阿里云对象存储如何助力钉钉战胜业务洪峰

“基于OSS在弹性扩容、跨省容灾、多租户管理以及传输加速方面的基础能力&#xff0c;钉钉在此次战役过程中&#xff0c;实现了一键切换写入区域&#xff0c;拆分业务到多个区域的功能&#xff0c;同时钉钉在跨区域的图片处理、文档预览的并发处理量上有了10倍速的提升。”——钉…

知乎高赞:一行代码凭什么躺普通程序员的10年工资?

笔者这两天闲逛知乎&#xff0c;看到了这个帖子&#xff1a;匿名答题&#xff0c;发表于2014年&#xff0c;此外没有留下任何多余信息。2年躺赚200万&#xff0c;相当于普通程序员10年的工资。没想到Pyhon这么强大&#xff0c;怪不得有人说“除了不会生孩子&#xff0c;Python什…

第九弹 - 脚本模式与参数视图

MaxCompute&#xff08;原ODPS&#xff09;是阿里云自主研发的具有业界领先水平的分布式大数据处理平台, 尤其在集团内部得到广泛应用&#xff0c;支撑了多个BU的核心业务。 MaxCompute除了持续优化性能外&#xff0c;也致力于提升SQL语言的用户体验和表达能力&#xff0c;提高…

Vue3---安装Element-Plus组件库

*** 全局安装Element-Plus 1. npm安装 npm install element-plus --save 2. 在main.js中引入以下内容 import { createApp } from vue import ElementPlus from element-plus import element-plus/dist/index.css import App from ./App.vue const app createApp(App…

在家“隔离”这1个月,阿里云视频云这些工程师都经历了什么?

战"疫”当前&#xff0c;没有谁会置身事外。从1月底开始&#xff0c;一场全民疫情阻击战拉开帷幕&#xff0c;企业停工、学校停课、商场停业&#xff0c;城市街道分外冷清&#xff0c;相反的是&#xff0c;无法出门的数亿网民却在互联网上掀起了一阵不小的流量热潮。距离2…

CSDN的常用文本设置(字体大小红色)

<font face"黑体" color#FF0000 size4> **在这里放入需要修改颜色的语句**</font>在这里放入需要修改颜色的语句

让安全威胁无所遁形,全方位掌握攻击“前世今生”的黑科技来了

作者 | 伍杏玲出品 | CSDN&#xff08;ID:CSDNnews&#xff09;据启明星辰发布的《2019~2020网络安全态势观察报告》显示&#xff0c;在过去一年多时间里&#xff0c;勒索攻击由 2014 年的广泛无目的的传播阶段到2017 年 WannaCry 带来的大规模自动化传播阶段&#xff0c;如今已…

Vue3---vue组件库

1.vue-form-making 基于 vue 和 element-ui 实现的表单设计器&#xff0c;使用了最新的前端技术栈&#xff0c;内置了 i18n 国际化解决方案&#xff0c;可以让表单开发简单而高效。 项目地址&#xff1a;https://gitee.com/gavinzhulei/vue-form-making 2.viewUI ViewUI 是…