概述
前言
因为要做签到,所以要写了个日历。
只有基础的日历,签到需要自行实现。
(我等下也要实现签到了…)
效果图
wxml
<view class="sign-wrapper">
<view class="calendar">
<view class="month">
<view class="item" wx:for="{{ week }}">
{{ item }}
</view>
<view class="item {{ item.type != 'curr' ? 'othe' : '' }}"
wx:for="{{ dateData }}">
{{ item.day }}
</view>
</view>
</view>
</view>
登录后复制
wxss
.calendar{
margin-top: 10%;}.month{
display: flex;
flex-flow: row wrap;
font-size: 1.1rem; }.item{
width: 14.28%;
text-align: center;
line-height: 3rem;}.othe{
color: grey}
登录后复制
js
// pages/sing_in/sing_in.jsPage({
data: {
dateData: [],
isSignin: false,
week: ['日','一','二','三','四','五','六'],
},
onLoad: function (options) {
this.initCurrMonthData()
},
/**
* year string 年 如:2020
* month string 月 如: 5
* return array 所有天数 如:[1,2,3...,31]
**/
monthDays(year,month){
let days_count = new Date(year,month,0).getDate() //月总天数 如:31
let days = []; //存放月的天数
for(let i = 1; i <= days_count; i++)
days.push(i)
return days;
},
//初始化当月数据
initCurrMonthData(){
let currDate = new Date(); //当前日期
let currMonthDays = this.monthDays(currDate.getFullYear(),currDate.getMonth() + 1) //当月 +1是因为月从0开始 只有0-11
let lastMonthDays = this.monthDays(currDate.getFullYear(),currDate.getMonth() ) //上个月
let currFirstWeek = new Date(currDate.getFullYear(),currDate.getMonth() - 1, 1).getDay() + 1; //这个月的1号是星期几 -1是因从0开始
//月最后一天是星期几
let dateData = [];
dateData = currMonthDays.map(val => this.formatDay(val)) //当月的数据
for(let i = 0; i < currFirstWeek; i++) //上月要显示的
dateData.unshift(
this.formatDay( lastMonthDays.pop(),'last')
);
let nextLenth = 42 - dateData.length; // 42是因为 6 * 7格式
for(var i = 1; i <= nextLenth; i++) //下个月需要显示的日期
dateData.push(
this.formatDay( i, 'next')
);
this.setData({
dateData : dateData })
},
formatDay(day,type = 'curr'){ //日期数据的格式化
return {day:day,type:type};
},
onShareAppMessage: function () {
}})
登录后复制
以上就是微信小程序实现签到的日历功能的详细内容,更多请关注靠谱客其它相关文章!
最后
以上就是勤劳樱桃为你收集整理的微信小程序实现签到的日历功能的全部内容,希望文章能够帮你解决微信小程序实现签到的日历功能所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复