左右滑动日历(微信小程序)

最近因为某些原因,又在自己的小程序业务组件项目中添加了可左右滑动的日历。

实现思路

获取每月的总天数,使用getDate()

	getTotalDays(date) {
		let value = new Date(date.year, date.month, 0).getDate()
		return value
	}

每月1号是周几,使用getDay()

	getFirstDayWeek(date) {
		return new Date(date.year, date.month - 1, 1).getDay()
	}

计算上个月和下个月的残余天数:根据每月的1号是周几计算出上个月的残余天数,根据每月总天数得知上个月的最后一号;日历上显示的日期总个数为7的倍数,由此计算出下个月的残余天数

		// 根据当前的天数,计算上月残余天数和下月残余天数
		calculateResidualDays(date) {
			// 计算上月残余天数,需要知道1号是星期几(个数)且上月最后一天是几号(起始数值)
			let last_value = dateUtil.getTotalDays({
				year: date.year,
				month: date.month - 1
			})
			for (let i = 0; i < date.firstDayWeek; i++) {
				date.list.unshift({
					value: this.properties.showRemnantDays ? last_value - i : '',
					type: 'last'
				})
			}

			// 计算下月残余天数,需要知道本月显示多少行
			let total = Math.floor(date.list.length / 7)
			if (date.list.length % 7 > 0) {
				++total
			}
			if (this.properties.fixRow) {
				// 设置了每月固定显示6行
				total = 6
			}
			let next_value = total * 7 - date.list.length

			// 设置滚动框的高度,设置变化的过度动画
			date.swiperHeight = total * 107
			for (let i = 1; i <= next_value; i++) {
				date.list.push({
					value: this.properties.showRemnantDays ? i : '',
					type: 'next'
				})
			}
			
			//	格式化显示的提示信息
			this.formatShowTip(date)
		},

这样,一个月的相关日期便可以计算出来,其他的相关功能及思路,可见我的github

原文链接

小白一枚,要是实现思路有问题或者是代码写得不好,欢迎指正
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值