历时半年,我发布了一款习惯打卡小程序

半年多前,我一直困扰于如何记录习惯打卡情况,在参考了市面上绝大多数的习惯培养程序后,终于创建并发布了这款习惯打卡小程序。

"我的小日常打卡"小程序主要提供习惯打卡和专注训练功能。致力于培养用户养成一个个好的习惯,改掉生活中的拖延症!

代码技术

服务端:使用PHP+MySQL编写服务端接口

前端:使用UniApp开发并封装成微信小程序

图片存储:使用七牛云存储日志图片

界面截图介绍

一、首页打卡界面

显示当天需要打卡的习惯,点击白色圈的图片即可打卡成功;(可操作单个习惯一天打卡多次)

习惯显示列表

二、习惯统计

支持按天、按周、按月、按年度显示打卡情况;

当天打卡数据显示

日历使用的是uniapp自带的uni-calendar组件,只是自行修改了样式,样式代码如下:

css 复制代码
<style scoped>
	.uni-calendar--hook>>>.uni-calendar__content {
		border-radius: 20rpx;
		font-weight: 500;
	}

	/* 日历头部 */
	.uni-calendar--hook>>>.uni-calendar__header {
		height: 40px;
	}

	/* 日历星期 */
	.uni-calendar--hook>>>.uni-calendar__weeks-day {
		height: 35px;
		font-weight: normal;
	}

	.uni-calendar--hook>>>.uni-calendar__backtoday {
		top: auto;
	}

	/* 日历主体 */
	/* 已打卡和补卡设置 */
	.uni-calendar--hook>>>.uni-calendar-item__weeks-box-item {
		height: 60rpx;
		width: 60rpx;
	}

	.uni-calendar--hook>>>.uni-calendar__weeks {
		margin: 20rpx 0;
	}

	.uni-calendar--hook>>>.uni-calendar__weeks:first-child {
		margin: 0;
	}


	/* 设置背景颜色 */
	.uni-calendar--hook>>>.uni-calendar-item--signed .uni-calendar-item__weeks-box-item {
		/* background-color: red; */
		border-radius: 60rpx;
		width: 60rpx;
		height: 60rpx;
	}

	.uni-calendar--hook>>>.uni-calendar-item--un-signed .uni-calendar-item__weeks-box-item {
		background-color: #f9ae3d;
		border-radius: 60rpx;
		width: 60rpx;
		height: 60rpx;
	}

	/* 去掉禁选背景颜色 */
	.uni-calendar--hook>>>.uni-calendar-item--signed .uni-calendar-item--disable,
	.uni-calendar--hook>>>.uni-calendar-item--un-signed .uni-calendar-item--disable {
		background-color: transparent;
	}

	.uni-calendar--hook>>>.uni-calendar-item--signed .uni-calendar-item--extra,
	.uni-calendar--hook>>>.uni-calendar-item--un-signed .uni-calendar-item--extra {
		display: none;
	}

	.uni-calendar--hook>>>.uni-calendar-item--signed .uni-calendar-item__weeks-box-text,
	.uni-calendar--hook>>>.uni-calendar-item--un-signed .uni-calendar-item__weeks-box-text {
		color: #fff;
	}

	.uni-calendar--hook>>>.uni-calendar-item--isDay {
		background-color: transparent;
		color: #f9ae3d;
		opacity: 1;
		line-height: normal;
	}

	.uni-calendar--hook>>>.uni-calendar-item--isDay-text {
		color: #333;
	}

	/* 去掉右上角圆圈 */
	.uni-calendar--hook>>>.uni-calendar-item__weeks-box-circle {
		background-color: #f9ae3d;
		display: none;
	}

	/* 移除选中样式 */
	.uni-calendar--hook>>>.uni-calendar-item--checked {
		background-color: transparent;
		color: #333;
		opacity: 1;
	}
</style>

打卡详细数据显示

按周、按月显示打卡统计

年度打卡统计显示

三、专注训练

提供番茄专注倒计时,训练专注能力。专注统计数据显示如下:

专注训练这块的数据图表生成,我并没有使用他人封装好的echarts相关组件,而是选择可官方提供的一个小程序版本的echarts-for-weixin组件。饼状图生成代码如下:

js 复制代码
<template>
    <uni-ec-canvas class="uni-ec-canvas" id="day-canvas" ref="dayCanvas" canvas-id="day-canvas" :ec="ec"></uni-ec-canvas>
</template>
<script>
export default {
    data() {
        ec: {
                lazyLoad: true
        },
        optionDay: {
                color: [],
                series: [{
                        type: 'pie',
                        data: [],
                        label: {
                                formatter: params => {
                                        // console.log(params);
                                        let str = params.data.name;
                                        let duration = params.data.value;
                                        let timeStr = '';
                                        if (params.data.value > 0) {
                                                if (duration >= 60) {
                                                        // 格式化时分
                                                        let hour = Math.floor(duration / 60);
                                                        let minute = duration - hour * 60;

                                                        timeStr += hour + '小时' + minute + '分';
                                                } else {
                                                        timeStr += duration + '分';
                                                }
                                        }
                                        return str + '\n' + timeStr;
                                }
                        },
                        radius: '70%'
                }]
        },
    },
    
    methods: {
        getDetails() {
            this.$nextTick(() => {
                // ajax请求数据并绘图
                setTimeout(() => {
                        this.$refs.dayCanvas.init(this.initDayChart);
                }, 300);
        });
        }
    }
}
</script>

四、其他功能

个人中心提供其他更多功能,如与好友在一个打卡组中进行打卡,记录打卡日志和早起打卡瓜分奖金等

相关推荐
swipe1 天前
从 0 到 1 实现大文件上传:分片、秒传、断点续传、暂停、重试与服务端合并
前端·javascript·面试
kyriewen1 天前
AI 生成的代码能跑就行?这 5 个坑迟早炸
前端·javascript·ai编程
kisshyshy1 天前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
胡志辉1 天前
从v8源码和react深入浅出理解 JavaScript 作用域链与闭包
前端·javascript
Bolt1 天前
TypeScript 7.0 来了:当 tsc 用 Go 重写之后
javascript·typescript·go
阳火锅1 天前
😭测试小姐姐终于不骂我了!这个提BUG神器太香了...
前端·javascript·面试
林希_Rachel_傻希希1 天前
js里面的proxy理解。以及vue3响应式数据设计底层
前端·javascript·面试
阿黎梨梨1 天前
AI Loop:告别“人肉写提示词”,让代码替你“鞭策”AI
javascript·人工智能
竹林8181 天前
用 wagmi v2 + viem 监听链上事件,我踩了三天坑终于搞懂了实时日志与历史补全
javascript
只一1 天前
😭从回调地狱到 async/await:一文打通 Ajax 与 JS 异步编程
javascript