微搭低代码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. 标记已读:点击消息后标记为已读,更新状态
相关推荐
卷叶小树1 天前
低代码属性面板-Setter体系与高级配置
低代码·前端框架
葡萄城技术团队1 天前
活字格:打通 ERP 与车间执行数据,实现计划与生产协同
低代码
SL_staff1 天前
《如何用规则引擎替代if-else?JVS-Rules可视化编排比硬编码强在哪里?》
java·低代码·架构
ZKNOW甄知科技1 天前
燕千云AI-ITR系列:三线分层机制的标准化解决方案
大数据·运维·人工智能·低代码·自然语言处理·自动化·敏捷流程
API开发平台1 天前
开源 API 开发平台 5.2.0 发布
低代码·开源
UXbot1 天前
移动端UI设计工具选型指南:iOS与Android设计标准支持对比
android·前端·低代码·ios·交互·团队开发·ui设计
贺国亚1 天前
低代码AI平台-Dify-Coze与企业落地
人工智能·低代码
UXbot2 天前
AI网页开发工具能替代工具吗?5大平台对比
前端·人工智能·低代码·ui·原型模式·web app
yinmaisoft2 天前
JNPF 三大主流行业解决方案,按需定制
大数据·低代码·开发工具
SL-staff2 天前
Vue3私有化AI白板落地实战|解决政企项目智能绘图合规难题(可直接复用源码)
人工智能·低代码·开源·vue3·白板·jvs规则引擎·jvs-draw