iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >微信小程序实现计时器
  • 577
分享到

微信小程序实现计时器

2024-04-02 19:04:59 577人浏览 安东尼
摘要

本文实例为大家分享了微信小程序实现计时器的具体代码,供大家参考,具体内容如下 微信小程序点击事件触发计时器 1.wxml <view class="button" bindt

本文实例为大家分享了微信小程序实现计时器的具体代码,供大家参考,具体内容如下

微信小程序点击事件触发计时器

1.wxml

<view class="button" bindtap="open_modal">开始巡查</view>
 
<!-- 弹出层 -->
<view class="mask-bg" wx:if="{{showModal}}"></view>
<view class="mask-item" wx:if="{{showModal}}">
    <view class="mask-top-item">
        <view class="mask-top-title">计时器</view>
        <image class="close-item-img" src="/images/task/close.png" bindtap="close"></image>
    </view>
    <view class="collect-time">{{showHour}}:{{showMin}}:{{showSec}}</view>
    <!-- <view class="divLine2"></view> -->
    <block wx:if="{{showStop}}">
        <image class="start-img" src="/images/task/stop.png" bindtap="stop"></image>
    </block>
    <block wx:elif="{{!showStop}}">
        <image class="start-img" src="/images/task/start.png" bindtap="start"></image>
    </block>
    <image class="bottom-bg" src="/images/task/bg.png"></image>
</view>

2.js

var util = require('../../utils/util.js');
data: {
    showModal: false,
    showStop:false,
    //存储计时器
    setInter: '',
    hour: 1,
    min: 1,
    sec: 1,
    showSec: "00",
    showMin: "00",
    showHour: "00"
  },
 
open_modal: function () {
    var that = this;
    that.setData({
      showModal: true,
    })
  },
 
// 开始计时
start: function () {
    var that = this;
    that.setData({
      showStop: true
    })
    wx.showToast({
      title: '开始计时',
      duration: 1000,
      complete() {
        // 获取开始时间
        var beginTime = util.fORMatTime(new Date());
        console.log(beginTime)
 
        console.log("开始计时")
        //将计时器赋值给setInter
        that.data.setInter = setInterval(
          function () {
            if (that.data.sec != 60) {
              if (that.data.sec <= 9) {
                let showSec = '0' + that.data.sec
                that.setData({
                  showSec: showSec,
                  sec: that.data.sec + 1,
                })
              } else {
                that.setData({
                  showSec: that.data.sec,
                  sec: that.data.sec + 1,
                })
              }
            } else {
              if (that.data.min != 60) {
                // 60s 进 1min
                if (that.data.min <= 9) {
                  let showMin = '0' + that.data.min
                  that.setData({
                    sec: 0,
                    showSec: "00",
                    showMin: showMin,
                    min: that.data.min + 1,
                  })
                } else {
                  that.setData({
                    sec: 0,
                    showSec: "00",
                    showMin: that.data.min,
                    min: that.data.min + 1,
                  })
                }
              } else {
                // 60min 进 1hour
                if (that.data.hour != 24) {
                  if (that.data.hour <= 9) {
                    let showHour = '0' + that.data.hour
                    that.setData({
                      min: 0,
                      showMin: "00",
                      showHour: showHour,
                      hour: that.data.hour + 1,
                    });
                  } else {
                    that.setData({
                      min: 0,
                      showMin: "00",
                      showHour: that.data.hour,
                      hour: that.data.hour + 1,
                    });
                  }
                } else {
                  //24小时
                  var endTime = util.formatTime(new Date());
                  console.log(endTime)
 
                  console.log("结束计时")
                  //清除计时器  即清除setInter
                  clearInterval(that.data.setInter);
                  that.setData({
                    showModal: false,
                    showStop: false,
                    sec: 1,
                    min: 1,
                    hour: 1,
                    showSec: "00",
                    showMin: "00",
                    showHour: "00"
                  })
                }
              }
            }
          }, 1000);
      }
    });
  },
 
  // 停止计时
  stop: function () {
    var that = this;
    wx.showModal({
      title: '提示',
      content: '是否确定退出',
      showCancel: true,
      cancelText: '继续',
      cancelColor: '#000000',
      confirmText: '确定退出',
      confirmColor: '#1677FF',
      success: (result) => {
        if (result.confirm) {
          // 获取结束时间
          var endTime = util.formatTime(new Date());
          console.log(endTime)
 
          console.log("结束计时")
          //清除计时器  即清除setInter
          clearInterval(that.data.setInter);
          that.setData({
            showModal: false,
            showStop: false,
            sec: 1,
            min: 1,
            hour: 1,
            showSec: "00",
            showMin: "00",
            showHour: "00"
          })
        }
      },
      fail: () => {},
      complete: () => {}
    });
    
  },
 
  // 关闭模态框方法
  close: function () {
    var that = this;
    // 判断点击关闭时状态
    if (that.data.showStop) {
      //点击开始后关闭
      that.stop_inspection();
    } else if (!that.data.showStop) {
      // 没有开始就关闭
      that.setData({
        showModal: false,
      })
    }
  },

3.wxss

.button {
    margin-top: 32rpx;
    width: 702rpx;
    height: 98rpx;
    background: #1677FF;
    border-radius: 8rpx;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 36rpx;
    font-family: PingFangSC-Regular, PingFang SC;
    font-weight: 400;
    color: #FFFFFF;
}
 
.mask-bg {
    position: absolute;
    top: 0%;
    left: 0%;
    width: 100%;
    height: 100%;
    background-color: black;
    z-index: 1001;
    -moz-opacity: 0.7;
    opacity: 0.70;
    filter: alpha(opacity=70);
}
 
.mask-item {
    text-align: center;
    position: absolute;
    top: 24.5%;
    left: 8%;
    width: 84%;
    height: 55.5%;
    border-radius: 8rpx;
    
    background-color: #FFFFFF;
    z-index: 1002;
    overflow: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
}
 
.mask-top-item {
    height: 128rpx;
    width: 100%;
    background-color: #1677FF;
    z-index: 1003;
    display: flex;
    align-items: center;
}
 
.mask-top-title {
    width: 240rpx;
    height: 50rpx;
    font-size: 36rpx;
    font-family: PingFangSC-Medium, PingFang SC;
    font-weight: 500;
    color: #FFFFFF;
    margin-left: 200rpx;
}
 
.close-item-img {
    margin-left: 115rpx;
    width: 44rpx;
    height: 44rpx;
}
 
.collect-time {
    margin-top: 112rpx;
    width: 552rpx;
    height: 116rpx;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 120rpx;
    font-family: ArialMT;
}
 

 
.start-img {
    margin-top: 64rpx;
    height: 176rpx;
    width: 176rpx;
}
 
.bottom-bg{
    width: 100%;
    height: 93rpx;
    position: absolute;
    bottom:0%;
    z-index: 1003;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: 微信小程序实现计时器

本文链接: https://www.lsjlt.com/news/167250.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 微信小程序实现计时器
    本文实例为大家分享了微信小程序实现计时器的具体代码,供大家参考,具体内容如下 微信小程序点击事件触发计时器 1.wxml <view class="button" bindt...
    99+
    2024-04-02
  • 微信小程序实现倒计时
    本文实例为大家分享了微信小程序实现倒计时的具体代码,供大家参考,具体内容如下 大家好,今天我们来学习一下倒计时的实现,好好看,好好学,超详细的。 直接上代码吧 <view cl...
    99+
    2024-04-02
  • 微信小程序如何实现倒计时
    这篇文章主要介绍“微信小程序如何实现倒计时”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“微信小程序如何实现倒计时”文章能帮助大家解决问题。直接上代码吧<view class=&quo...
    99+
    2023-06-30
  • 微信小程序实现答题倒计时
    想做一个答题的计时器效果,本文为大家分享了微信小程序实现答题倒计时的具体代码,供大家参考,具体内容如下 思路 利用canvas不停的画弧线 效果 代码 wxml <view...
    99+
    2024-04-02
  • 微信小程序实现小型计算器
    本文实例为大家分享了微信小程序实现小型计算器的具体代码,供大家参考,具体内容如下 app.js // app.js App({   onLaunch() {   },   REGEX...
    99+
    2024-04-02
  • 微信小程序实现验证码倒计时
    本文实例为大家分享了微信小程序实现验证码倒计时的具体代码,供大家参考,具体内容如下 wxml代码: <view class='container'>   <form...
    99+
    2024-04-02
  • 微信小程序实现短信验证码倒计时
    本文实例为大家分享了微信小程序实现短信验证码倒计时的具体代码,供大家参考,具体内容如下 初始效果 当点击按钮时候设置禁止点击效果:如下图 话不多说,直接上代码 1.wxml部分 ...
    99+
    2024-04-02
  • 微信小程序实现计算器小功能
    微信小程序现在越来越火爆了,我也看到很多在校大学生都在自学了,那些专门从事APP开发,网页开发的工作者更是看到了小程序的前景,在小程序领域也掺上一脚,本人也是自学小程序的,初期跟很多...
    99+
    2024-04-02
  • 微信小程序实现简单倒计时功能
    本文实例为大家分享了微信小程序实现简单倒计时的具体代码,供大家参考,具体内容如下 任务描述: 计时器 任务要求: 案例描述:设计一个实现倒计时功能的小程序,小程序运行后,首先显示空白...
    99+
    2024-04-02
  • 微信小程序倒计时功能怎么实现
    微信小程序的倒计时功能可以通过使用setInterval函数来实现。 首先,在页面的js文件中定义一个变量,用于存储倒计时的时间: ...
    99+
    2024-02-29
    微信小程序
  • 微信小程序实现利息计算器
    本文实例为大家分享了微信小程序实现利息计算器的具体代码,供大家参考,具体内容如下 一、案例说明 设计一个小程序,输入本金、利率,默认本金10000元、利率3%,计算存入银行,复利计息...
    99+
    2024-04-02
  • 微信小程序实现计算器功能
    本文实例为大家分享了微信小程序实现计算器功能的具体代码,供大家参考,具体内容如下 一、微信小程序开发工具界面 二、目录结构 第一次进到页面它的目录结构如下: 三、需要注意的问题 ...
    99+
    2024-04-02
  • 微信小程序实现简易计算器
    微信小程序之简易计算器,供大家参考,具体内容如下 一、介绍 1.中缀表达式 中缀表达式是一种通用的算术或逻辑公式表示方法,操作符以中缀形式处于操作数的中间。中缀表达式是人们常用的算术...
    99+
    2024-04-02
  • 微信小程序实现简单计算器
    微信小程序写的简单计算器,供大家参考,具体内容如下 jisaunqi.js // pages/jisuanqi/jisuanqi.js Page({ data: {...
    99+
    2024-04-02
  • 微信小程序实现计算器案例
    本文实例为大家分享了微信小程序实现计算器的具体代码,供大家参考,具体内容如下 项目展示 页面设计 分为上面输入的显示部分和下面按键部分 <!--pages/index/i...
    99+
    2024-04-02
  • 微信小程序实现时间轴
    本文实例为大家分享了微信小程序实现时间轴的具体代码,供大家参考,具体内容如下 一、显示样式 二、代码  1.wxml: <view class="header"&g...
    99+
    2024-04-02
  • 微信小程序实现验证码倒计时效果
    本文实例为大家分享了微信小程序验证码倒计时效果的具体代码,供大家参考,具体内容如下 如果写过js的倒计时,那么小程序中使用也是差不多的; 代码: data: {       daoj...
    99+
    2024-04-02
  • 微信小程序实现发送短信验证码倒计时
    本文实例为大家分享了微信小程序发送短信验证码倒计时的具体代码,供大家参考,具体内容如下 效果图 WXML文件 <view class="container"> ...
    99+
    2024-04-02
  • 微信小程序电商常用倒计时实现实例
    微信小程序电商常用倒计时实现实例wxml文件放个text<text>second: {{second}} micro second:{{micro_second}}</text>在js文件中调用function co...
    99+
    2023-05-31
    微信小程序 倒计时 信小
  • 微信小程序如何实现短信验证码倒计时
    这篇文章主要讲解了“微信小程序如何实现短信验证码倒计时”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“微信小程序如何实现短信验证码倒计时”吧!初始效果当点击按钮时候设置禁止点击效果:如下图话不...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作