微搭低代码MBA 培训管理系统实战 36——消息通知功能

目录

前情回顾与本节目标

在上一节中,我们完成了小程序端的课程预约功能。本节我们将实现消息通知功能,学员可以查看各类消息通知,包括课程提醒、公告、生日祝福等。

本节核心目标:

  • 消息列表展示:显示消息列表,包含不同类型和状态
  • 未读统计:显示未读消息数量
  • 标记已读:点击消息后标记为已读

第一步:数据模型准备

消息通知表(MBA_Messages)

字段名称 字段标识 字段类型 说明
消息ID _id 文本 主键,系统自动生成
关联学员 rel_student_id 多对一 关联 StudentProfiles 表
消息类型 type 枚举 1-课程提醒、2-补课提醒、3-生日祝福、4-班级公告、5-系统通知
消息标题 title 文本 消息标题
消息内容 content 文本 消息内容
是否已读 is_read 布尔值 是否已读
发送时间 send_time 日期时间 发送时间

第二步:创建页面

点击创建页面 图标,输入"消息通知",选择tab栏导航布局

切换到布局设计,添加菜单


第三步:页面布局

3.1 页面头部

添加容器组件,设置宽、高和背景色:

css 复制代码
:root {
  width: 100%;
  min-height: 100vh;
  background-color: #F6F7F9;
}

继续添加普通容器,设置背景色、内边距和圆角:

css 复制代码
:root {
  background: linear-gradient(135deg, #3b82f6 0%, #1d4ed8 100%);
  padding: 48px 20px 24px 20px;
  border-radius: 0 0 24px 24px;
}

里边添加两个文本组件,设置普通容器的布局为横向排列,两端对齐

设置文本的字体颜色

3.2 头部数据绑定

创建内置数据表查询,数据模型选择消息通知表,方法选择查询多条

配置查询条件,关联学员等于全局变量的数据标识

bash 复制代码
$w.app.dataset.state.currentUser._id

是否已读设置为false

给文本组件绑定文本内容,绑定未读数量

bash 复制代码
$w.queryMessage.data.total+'条未读'

第四步:消息列表区域

添加数据列表组件 ,数据模型选择MBA_Messages

设置普通容器的背景色和外阴影

给图标组件绑定条件展示,未读的时候显示

bash 复制代码
!$w.item_listView1.is_read

第五步:标记已读功能

创建自定义方法 markAsRead

javascript 复制代码
export default async function markAsRead({ event, data }) {
  try {
    const message = data.target;
    
    // 如果已经是已读,不处理
    if (message.is_read) {
      return;
    }
    
    $w.utils.showLoading({ title: '处理中...' });
    
    // 更新消息为已读
    await $w.cloud.callDataSource({
      dataSourceName: 'MBA_Messages',
      methodName: 'wedaUpdateV2',
      params: {
        data: {
          is_read: true,
        },
        filter: {
          where: {
            _id: { $eq: message._id }
          }
        }
      }
    });
    
    $w.utils.hideLoading();
    
    // 刷新列表
    $w.listView1.refresh({})
    $w.queryMessage.trigger()
    
  } catch (e) {
    console.error('标记已读失败', e);
    $w.utils.hideLoading();
  }
}

给容器设置点击事件,调用方法,传入所在行数据

最终效果

切换到消息页面,列出所有消息

总结

本节完成了消息通知功能的实现:

  1. 消息列表展示:显示消息列表,包含类型图标、标题、内容、时间
  2. 未读标识:未读消息左侧蓝色边框,标题加粗,显示红点
  3. 标记已读:点击消息后标记为已读,更新状态
相关推荐
C澒15 小时前
AI 生码 - API2Code:接口智能匹配与 API 自动化生码全链路设计
前端·低代码·ai编程
低代码布道师1 天前
微搭低代码MBA 培训管理系统实战 35——教务端预约详情与黑名单管理
低代码
低代码布道师1 天前
微搭低代码MBA 培训管理系统实战 36——小程序端课程预约功能实现
低代码·小程序
C澒2 天前
AI 生码 - API2CODE:接口智能匹配与 API 自动化生码实践
前端·低代码·ai编程
Java小卷3 天前
低代码并没有过时!可拖拽表单设计器布局思路
前端·低代码
C澒4 天前
AI 生码 - D2C:Figma to Code 全流程实现
前端·低代码·ai编程·figma
老刘说AI4 天前
Text2SQL到数据智能
人工智能·python·低代码·语言模型·langchain
mpp0075 天前
《从需求到上线:CodeWave SpecDriven 模式企业级应用开发全流程指南》
低代码·aigc
踩着两条虫5 天前
VTJ 平台六大设计模式落地实战指南
开发语言·前端·人工智能·低代码·设计模式·重构·架构