微搭低代码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. 标记已读:点击消息后标记为已读,更新状态
相关推荐
树上有只程序猿13 小时前
主流低代码管理平台深度解析(最新)
人工智能·低代码·软件开发·软件需求
搭贝20 小时前
如何用低代码平台搭建智能商机跟进系统——搭贝实战
低代码
Jeking2171 天前
低代码平台 表单设计器 unione form editor 功能组件 —— 悬浮按钮组件
低代码·动态表单·表单设计·表单引擎·unione cloud
2501_912784083 天前
跨境多语种页面适配方案:低代码SaaS落地实测
低代码
Jeking2173 天前
实战案例|快捷键盘组件在仓库 PDA 入库表单中的落地应用
低代码·动态表单·表单设计·表单引擎·unione cloud
Jeking2173 天前
低代码平台 unione form editor 功能组件 —— 快捷键盘组件
低代码·动态表单·表单设计·表单引擎·unione cloud
lianyinghhh4 天前
FlowGame 从零上手:开源 AI 工作流编排框架与 Vue 3 接入实战
python·低代码·开源·vue·rag·flowgame·ai工作流编排
搭贝4 天前
如何用低代码平台搭建企业级合同审查系统——搭贝实战
低代码
踩着两条虫4 天前
VTJ.PRO v2.4.0 多人协作与 AI 批量识图实战评测
vue.js·人工智能·低代码·figma
token-go5 天前
Means:基于 .NET 10 打造的开源自部署 S3 兼容对象存储服务
低代码·.net·rxjava