从0到100:单位订餐统计小程序开发日记2025

可行性分析

单位订餐统计小程序:员工可快速查看每日菜品及价格。支持多种菜品选择,可按需添加数量,满足不同口味需求。自动记录员工订餐信息,包括菜品、数量、金额等,方便查询历史订单。后台管理功能强大,可实时统计订单数量、金额,生成报表,便于财务结算与管理。同时支持订单修改、取消等操作,灵活适应突发情况。 通过小程序,实现订餐流程高效、透明,提升单位后勤管理效率与员工满意度。

概要设计

数据库设计

c 复制代码
GoodsModel.DB_STRUCTURE = {
	_pid: 'string|true',
	GOODS_ID: 'string|true',

	GOODS_TITLE: 'string|true|comment=标题',
	GOODS_STATUS: 'int|true|default=1|comment=状态 0=未启用,1=使用中',

	GOODS_SALE_CNT: 'int|true|default=0|comment=已购买数量',

	GOODS_CATE_ID: 'string|true|default=0|comment=分类',
	GOODS_CATE_NAME: 'string|false|comment=分类名冗余',

	GOODS_ORDER: 'int|true|default=9999',
	GOODS_VOUCH: 'int|true|default=0',

	GOODS_FORMS: 'array|true|default=[]',
	GOODS_OBJ: 'object|true|default={}',

	GOODS_QR: 'string|false',
	GOODS_VIEW_CNT: 'int|true|default=0',

	GOODS_COMMENT_CNT: 'int|true|default=0',

	GOODS_ADD_TIME: 'int|true',
	GOODS_EDIT_TIME: 'int|true',
	GOODS_ADD_IP: 'string|false',
	GOODS_EDIT_IP: 'string|false',
};
OrderModel.DB_STRUCTURE = {
	_pid: 'string|true',
	ORDER_ID: 'string|true',
	ORDER_USER_ID: 'string|true',

	ORDER_TOTAL_PRICE: 'float|true|default=0|comment=总价',
	ORDER_TOTAL: 'int|true|default=0|comment=数量',
	ORDER_LIST: 'array|true|comment=订单信息',
	ORDER_DAY: 'string|true|comment=日期',

	ORDER_DESC: 'string|false|comment=摘要',

	ORDER_STATUS: 'int|true|default=1|comment=状态 0=未确认,1=成功,9=取消',

	ORDER_ADD_TIME: 'int|true',
	ORDER_EDIT_TIME: 'int|true',
	ORDER_ADD_IP: 'string|false',
	ORDER_EDIT_IP: 'string|false',
};

核心实现

c 复制代码
class OrderService extends BaseProjectService {

	 

	async cancelMyOrder(userId, id) {
		let where = {
			_id: id,
			ORDER_USER_ID: userId,
			ORDER_STATUS: OrderModel.STATUS.COMM
		}
		let order = await OrderModel.getOne(where);
		if (!order) this.AppError('该订单不存在');


		await OrderModel.edit(where, { ORDER_STATUS: 9 });

		// 统计 
		this.statOrder(id);


	}

	async getMyOrderDetail(userId, id) {
		let where = {
			ORDER_USER_ID: userId,
			_id: id,
		}
		return await OrderModel.getOne(where);
	}


	async getMyOrdersList(userId, {
		search, // 搜索条件
		sortType, // 搜索菜单
		sortVal, // 搜索菜单
		orderBy, // 排序
		whereEx, //附加查询条件
		page,
		size,
		isTotal = true,
		oldTotal
	}) {

		orderBy = orderBy || {
			'ORDER_ADD_TIME': 'desc'
		};
		let fields = 'ORDER_ID,ORDER_DAY,ORDER_TOTAL,ORDER_TOTAL_PRICE,ORDER_DESC,ORDER_GOODS_ID,ORDER_ADD_TIME,ORDER_GOODS_TITLE,ORDER_GOODS_CNT,ORDER_SCORE,ORDER_STATUS,goods.GOODS_OBJ.cover';

		let where = {};
		where.and = {
			ORDER_USER_ID: userId,
			_pid: this.getProjectId() //复杂的查询在此处标注PID
		};

		if (util.isDefined(search) && search) {
			where.or = [
				{ ORDER_GOODS_TITLE: ['like', search] },
			];

		} else if (sortType && util.isDefined(sortVal)) {
			// 搜索菜单
			switch (sortType) {
				case 'status': {
					where.and.ORDER_STATUS = Number(sortVal);
					break;
				}
			}
		}

		return await OrderModel.getList(where, fields, orderBy, page, size, isTotal, oldTotal);
	}

}

UI设计






后台管理系统






git下载地址

点击下载

相关推荐
666HZ66611 小时前
微信小程序中scss、ts、wxml
微信小程序·小程序·scss
二十十十十十11 小时前
微信点餐小程序—美食物
微信·小程序
向明天乄11 小时前
在小程序中实现实时聊天:WebSocket最佳实践
websocket·网络协议·小程序
h1853859224411 小时前
租车小程序电动车租赁小程序php方案
小程序
海的诗篇_11 小时前
前端开发面试题总结-原生小程序部分
前端·javascript·面试·小程序·vue·html
说私域11 小时前
基于开源AI智能客服、AI智能名片与S2B2C商城小程序的微商服务质量提升路径研究
人工智能·小程序·开源
拼图20917 小时前
微信小程序——skyline版本问题
微信小程序·小程序
mg66818 小时前
微信小程序入门实例_____打造你的专属单词速记小程序
微信小程序·小程序
程序员陆通18 小时前
Vibe Coding开发微信小程序实战案例
微信小程序·小程序·notepad++·ai编程