微信小程序实现日历打卡

 更新时间:2022年08月29日 09:05:47   作者:PPAP__  
这篇文章主要为大家详细介绍了微信小程序实现日历打卡,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

样式比较简单,要改自己改

let currentMonthDays = new Date(year,month,0).getDate() 
//获取当前月份的天数
let startWeek = new Date(year + '/' + month + '/' + 1).getDay(); 
//本月第一天是从星期几开始的

首先要清楚以上两个方法的意思
下面直接上代码,逻辑很简单

wxml

<view class="context">
<view class="top">
  <image src="../../img/left.png" bindtap="bindPreMonth"></image>
  <view>{{year}}年{{month}}月</view>
  <image src="../../img/right.png" bindtap="bindNextMonth"></image>
</view>

<view  class="middle">
  <view wx:for="{{data_arr}}" wx:key="index" class="middle_num">
    {{item}}
  </view>
</view>

<view class="calen">

  <view wx:for="{{startWeek}}" wx:key="index" class="calen_blank"></view>
  <view wx:for="{{currentMonthDays}}" 
  class='{{index+1 == today ? "active": "calen_num"}}' 
    wx:key="index">
  {{index+1}}
  </view>
  
</view>

</view>

.js

Page({
  /**
   * 页面的初始数据
   */
  data: {
    data_arr:["日","一","二","三","四","五","六"],
    year:"",
    month:"",
    today:2 //这是固定2号这天打开,连续几天打卡就用数组就好了
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    let now = new Date()
    let year = now.getFullYear()
    // month获取是从 0~11
    let month = now.getMonth() + 1
    this.setData({
      year,month
    })
    this.showCalendar()
  },

  showCalendar(){
    let {year,month} = this.data
    //以下两个month已经+1
    let currentMonthDays = new Date(year,month,0).getDate() //获取当前月份的天数
    let startWeek = new Date(year + '/' + month + '/' + 1).getDay(); //本月第一天是从星期几开始的
    this.setData({
      currentMonthDays,startWeek
    })
  },

  //上个月按钮
  bindPreMonth(){
    let {year,month} = this.data
    //判断是否是1月
    if(month - 1 >= 1){
      month = month - 1 
    }else{
      month = 12
      year = year - 1
    }
    this.setData({
      month,year
    })
    this.showCalendar()
  },

  //下个月按钮
  bindNextMonth(){
    let {year,month} = this.data
    //判断是否是12月
    if(month + 1 <= 12){
      month = month + 1 
    }else{
      month = 1
      year = year + 1
    }
    this.setData({
      month,year
    })
    this.showCalendar()
  }
})

.css

.context{
  width: 96%;
  background-color: antiquewhite;
  margin: 0 auto;
  padding: 10rpx;
}
.top{
  height: 80rpx;
  display: flex;
  justify-content: space-around;
}
.top image{
  height: 30rpx;
  width: 30rpx;
}
.middle{
  display: flex;
}
.middle_num{
  width: 14%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.calen{
  display: flex;
  height: 400rpx;
  flex-wrap: wrap; /* 必要的时候拆行或拆列。 */
}
.calen_blank{
  width: 14%;
  height: 20%;
  background-color: pink;
}
.calen_num{
  width: 14%;
  height: 20%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.active{
  background-color: rgb(89, 111, 238);
  width: 14%;
  height: 20%;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 40rpx;
}

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

相关文章

  • JS获取地址栏参数的两种方法(简单实用)

    JS获取地址栏参数的两种方法(简单实用)

    这篇文章主要介绍了JS获取地址栏参数的两种方法(简单实用),小编给大家推荐使用第一种采用正则表达式获取地址栏参数的方法,此方法简单实用,对js获取地址栏参数相关知识感兴趣的朋友,一起学习吧
    2016-06-06
  • JavaScript 封装一个tab效果源码分享

    JavaScript 封装一个tab效果源码分享

    本文给大家分享javascript封装一个tab效果源码分享,感兴趣的朋友一起来看看吧
    2015-09-09
  • echarts折线图流动特效的实现全过程(非平滑曲线)

    echarts折线图流动特效的实现全过程(非平滑曲线)

    最近因为公司业务需求,需要实现,当Echarts重新加载数据时实现动态效果,下面这篇文章主要给大家介绍了关于echarts折线图流动特效实现的相关资料,需要的朋友可以参考下
    2023-03-03
  • typescript环境安装并开启VSCode自动监视编译ts文件为js文件

    typescript环境安装并开启VSCode自动监视编译ts文件为js文件

    这篇文章主要介绍了安装typescript环境并开启VSCode自动监视编译ts文件为js文件,本文教大家最基础的安装和配置自动监视ts文件编译成js文件,需要的朋友可以参考下
    2022-06-06
  • 一文让你彻底搞懂TypeScript(TS)和JavaScript(JS)区别与联系

    一文让你彻底搞懂TypeScript(TS)和JavaScript(JS)区别与联系

    TS是JS的超集,是一个可选的、静态的类型系统,下面这篇文章主要介绍了关于TypeScript(TS)和JavaScript(JS)区别与联系的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-04-04
  • JavaScript插件化开发教程 (三)

    JavaScript插件化开发教程 (三)

    前面我们学习了jQuery的方式开发插件,讲诉的都是些基础的理论知识,今天开始,我们就来实战一下,学习开发自己的插件库。
    2015-01-01
  • JavaScript异步Promise、Async、await使用举例详解

    JavaScript异步Promise、Async、await使用举例详解

    Promise 和 async/await 无疑是前端异步编程领域的两大得力工具,下面这篇文章主要介绍了JavaScript异步Promise、Async、await使用举例详解的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-04-04
  • js案例之鼠标跟随jquery版(实例讲解)

    js案例之鼠标跟随jquery版(实例讲解)

    下面小编就为大家带来一篇js案例之鼠标跟随jquery版(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • 使用Webpack构建多页面程序的实现步骤

    使用Webpack构建多页面程序的实现步骤

    这篇文章主要介绍了使用Webpack构建多页面程序的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • js实现input的赋值小结

    js实现input的赋值小结

    这篇文章主要介绍了js实现input的赋值问题小结,在实际的开发中,为了页面的美观,可能用到一些框架,比如EasyUI框架,文中介绍了easyui的input框赋值代码,感兴趣的朋友一起看看吧
    2023-12-12

最新评论