news 2026/4/23 17:53:20

【教培管家】小程序实战(五):体验课预约——从流量到转化的闭环

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【教培管家】小程序实战(五):体验课预约——从流量到转化的闭环

目录

  • ⏳ 前情回顾
  • 🎯 本节目标
  • 第一步:数据建模——预约表 (Bookings)
  • 第二步:页面变量与数据准备
  • 第三步:搭建“课包信息展示”区域
  • 第四步:搭建“学员选择”区域
  • 第五步:搭建“排课选择”区域 (横向日历+列表)
    • 5.1 数据准备
    • 5.2 搭建横向日历 UI
  • 最终效果
  • 🚀 总结与预告

⏳ 前情回顾

在上一讲中,我们完成了“首页整体装修”,通过精美的卡片展示了体验课套餐。当家长被课程吸引并点击“立即预约”时,我们需要一套完整的流程来引导他们完成学员选择、时段确认、在线支付


🎯 本节目标

  1. 预约建模:创建Bookings表,打通家长、学员、课包、排课与支付的关联。
  2. 变量驱动UI:使用页面变量控制学员选中、日期筛选及排课选中状态。
  3. 复杂交互搭建:实现课包信息展示、横向滚动的学员选择器与日历联动的排课列表。

第一步:数据建模——预约表 (Bookings)

预约表是连接家长、孩子、课程和资金的核心纽带。我们需要记录“谁(家长),给谁(孩子),买了什么课(课包+排课),付了多少钱”。

创建数据源:Bookings(预约表)

字段名称字段标识类型说明
关联课包course_package_id关联关系关联CoursePackage表,记录购买的套餐
关联排课schedule_id关联关系关联Schedule表,锁定具体上课时间
关联学员child_id关联关系关联Children表,记录上课学员
关联家长parent_id关联关系关联Parents表,记录支付人
预约编号bookingNo文本唯一订单号,规则:ORD+时间戳+随机数
支付金额amount数字实际支付金额(单位:元)
支付状态payStatus枚举1: 待支付,2: 已支付,3: 已取消
微信单号transaction_id文本微信支付回调返回的流水号

💡 设计思考:为什么既要关联Schedule又要关联CoursePackageCoursePackage决定了商品属性(如价格、课时数),而Schedule决定了服务履约的具体时间。


第二步:页面变量与数据准备

为了实现我们预约页面的多步选择,我们需要先创建变量保存用户的选择。点击创建页面的图标,创建预约页面



选中页面组件,我们创建一个URL参数,用来接收从首页传递过来的课程ID


在代码区点击新建,创建课包详情变量(courseInfo),类型选择内置数据表查询

数据模型选择套餐表,方法选择查询单条

查询条件设置为数据标识等于我们的URL参数

继续创建变量选中日期(selectedDate),类型选择数字,存储用户选择的上课日期,用于筛选排课列表。

继续创建变量,选中排课记录(selectedScheduleId),用于存储用户选中的排课记录 ID。

继续创建变量上课学员ID(selectedChildId),用于存储当前选中的上课学员 ID。


第三步:搭建“课包信息展示”区域

这是页面的第一部分,让家长确认自己正在购买什么产品。

首先给页面添加一个普通容器,设置页面的背景色

:root{min-height: 100vh;background-color:#F7F8FA;padding-bottom: 96px;}

然后在第一行的列里搭建我们的卡片布局,总体上是用普通容器结合图片和文本组件进行搭建

设置外层的普通容器的布局为横向排列

然后给图片绑定字段,从我们的courseInfo里绑定

最终效果


第四步:搭建“学员选择”区域

拖入一个普通容器,里边添加普通容器,放置图标和文本组件,搭建标题

继续添加普通容器,里边添加循环展示组件

循环展示组件里我们搭建头像和姓名布局,然后给循环展示绑定孩子列表数据

接着我们给外层的普通容器绑定样式,当选中的时候给一个蓝色的边框

$w.item_repeater1._id==$w.page.dataset.state.selectedChildId?{border:'2px solid #2563EB'}:{}

给容器设置点击事件,选中的时候给我们的变量进行赋值


第五步:搭建“排课选择”区域 (横向日历+列表)

这里我们将抛弃传统的日期选择器,采用更直观的横向日历切换,支持展示未来 15 天的排课信息。

5.1 数据准备

我们需要构建一个包含日期、星期、选中状态的数组。

先创建一个calendarList的变量,类型选择数组

在代码区新建一个自定义方法initCalendar,用于生成未来 15 天的数据。

exportdefaultfunction({event,data}){constdays=[];constweekMap=['周日','周一','周二','周三','周四','周五','周六'];for(leti=0;i<15;i++){constd=newDate();d.setDate(d.getDate()+i);d.setHours(0,0,0,0);constmonth=d.getMonth()+1;constdate=d.getDate();constdateStr=`${d.getFullYear()}-${String(month).padStart(2,'0')}-${String(date).padStart(2,'0')}`;days.push({id:i,date:dateStr,// 完整日期,用于查询label:i===0?'今日':weekMap[d.getDay()],// 显示文本value:d.getTime(),// 毫秒值,用于某些日期组件的绑定或计算displayDate:`${month}-${date}`,// 显示日期select:i===0// 默认选中第一天});}// 1. 更新日历数据$w.page.dataset.state.calendarList=days;// 2. 设置默认选中日期$w.page.dataset.state.selectedDate=days[0].date;}

方法创建好之后,在页面的onShow事件中调用即可

5.2 搭建横向日历 UI

横向滚动的效果要靠滚动容器来实现,先添加滚动容器,设置横向滚动

设置宽为340px

滚动容器里添加普通容器,布局设置为横向排列

继续添加循环展示组件,数据绑定为我们的日期列表

里边添加文本组件绑定我们的日期,具体的样式绑定和事件设置和我们第四部分是一样的,就不再赘述


最终效果

打开首页,点击立即预约

在打开的页面选择孩子、预约日期

🚀 总结与预告

本节我们通过变量状态管理数据联动,实现了孩子选择和日期选定。下一篇我们继续讲解预约页面,根据选择的日期来筛选排课,供用户进行预约。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 15:24:40

开发转行海洋科技:蓝碳经济中的3个入口

——软件测试从业者的专业转型指南引言&#xff1a;蓝碳经济的时代浪潮与测试人的机遇在全球气候治理的紧迫需求下&#xff0c;蓝碳经济正成为海洋生态保护与经济发展的核心引擎。蓝碳&#xff08;Blue Carbon&#xff09;指海洋生态系统通过光合作用固定的碳&#xff0c;主要包…

作者头像 李华
网站建设 2026/4/23 14:14:59

探秘 Fluent 水冷电机磁热仿真:从建模到温度场分析

fluent水冷电机磁热仿真、网格划分、前处理、3d建模、自然冷却温度场 单向耦合 双向耦合 磁热温度场分析在电机领域&#xff0c;随着技术不断精进&#xff0c;水冷电机因其高效散热性能受到广泛关注。Fluent 作为强大的仿真软件&#xff0c;为水冷电机的磁热分析提供了有力工具…

作者头像 李华
网站建设 2026/4/23 12:46:17

基于matlab的带点粒子在混合场运动的仿真模拟

- 标题&#xff1a; 基于matlab的带点粒子在混合场运动的仿真模拟 - 关键词&#xff1a;matlab GUI界面 电子 质子 自定义粒子 运动轨迹 电场 磁场 - 简述&#xff1a;针对不同混合场的情景&#xff0c;该模拟程序能准确画出带电粒子的运动轨迹。 关键词 matlab GUI界面 电子…

作者头像 李华
网站建设 2026/4/23 14:53:49

Ab3d.PowerToys 12.0 Crack

适用于 WPF 和 WinForms 的终极 3D 图形工具包 Ab3d.PowerToys 是一个功能强大的 WPF 和 WinForms 3D 工具包库&#xff0c;可大大简化使用科学、技术、CAD 或其他 3D 图形开发桌面应用程序的过程。 该库已在众多专业应用中得到验证。基于用户的积极反馈&#xff0c;它已发展成…

作者头像 李华
网站建设 2026/4/23 13:51:56

从过程性到面向对象:C++编程思维的飞跃

从过程性到面向对象&#xff1a;C编程思维的飞跃 过程性编程 vs 面向对象编程 在编程世界中&#xff0c;有两种主流的思维方式&#xff1a;过程性编程和面向对象编程。让我们通过一个实际的例子来理解它们的区别。 想象你是垒球队的数据记录员。如果采用过程性编程方法&…

作者头像 李华
网站建设 2026/4/23 14:18:27

与学习相关的技巧(超参数的验证)

超参数的验证 神经网络中&#xff0c;除了权重和偏置等参数&#xff0c;超参数&#xff08;hyper-parameter&#xff09;也经 常出现。这里所说的超参数是指&#xff0c;比如各层的神经元数量、batch 大小、参 数更新时的学习率或权值衰减等。如果这些超参数没有设置合适的值&a…

作者头像 李华