关于 Open UI5 MessageProcessor 消息创建的问题

举报
Jerry Wang 发表于 2023/03/19 09:51:47 2023/03/19
【摘要】 我们在单步调试 Open UI5 OData 模型或者 JSON 模型初始化代码时,都会发现 Open.ui.model.Model 构造函数调用了其基类 MessageProcessor 的构造函数,如下图所示:MessageProcessor 是 Open UI5 统一存储和管理各种类型的 Message 的实现类之一。以下是在 Open UI5 里手动创建消息或扩展框架提供的消息传递功...

我们在单步调试 Open UI5 OData 模型或者 JSON 模型初始化代码时,都会发现 Open.ui.model.Model 构造函数调用了其基类 MessageProcessor 的构造函数,如下图所示:

MessageProcessor 是 Open UI5 统一存储和管理各种类型的 Message 的实现类之一。

以下是在 Open UI5 里手动创建消息或扩展框架提供的消息传递功能的一些方法:

  • 可以通过中央 Open.ui.core.message.MessageManager API 手动创建自定义消息。 对于这些手动创建的消息,应用程序必须确保适当的消息生命周期。

  • 对于自定义目标格式,可以使用自定义消息处理器。 自己的消息处理器要继承类Open.ui.core.message.MessageProcessor。

  • 如果使用的后端以特殊方式提供消息,可以使用自己的Open.ui.core.message.MessageParser 实现。

Message Model

通过调用 getMessageModel() 方法从消息管理器中检索消息模型。可以直接在应用程序中使用它,也可以将它用作参考实现。

可以像使用任何其他模型一样使用消息模型将聚合绑定到根路径(/),例如列表中的项目,并添加过滤器和排序器。 /集合中的每个项目都代表一个 Open.ui.core.message.Message 对象,因此可以绑定到为此类对象指定的所有属性。 MessagePopover 控件用于向用户显示消息。

示例代码如下:

// "Button" required from "Open/m/Button"
// "MessagePopover" required from "Open/m/MessagePopover"
// "MessagePopoverItem" required from "Open/m/MessagePopoverItem"

var oMessagePopoverButton = new Button({
    text: "Show MessagePopover",
    type: "Accept",
    press: function() {
        oMP.openBy(this);
    }
});

var oMP = new MessagePopover({
    items: {
        path:"message>/",
        template: new MessagePopoverItem({ description: "{message>description}", type: "{message>type}", title: "{message>message}"})
    }
});

oMP.setModel(Open.ui.getCore().getMessageManager().getMessageModel(),"message");

oMessagePopoverButton.placeAt("content");

OData V2 Messages

OData V2 消息要么由 Open.ui.model.odata.ODataMessageParser 自动创建并由 Open.ui.model.odata.v2.ODataModel 处理,要么可以由应用程序手动创建。

这些消息的目标可以为空。 在这种情况下,消息没有特定目标并且与整个应用程序相关。如果设置了目标,则它必须对应于绑定路径,然后使用该路径将消息传播到相应的绑定。如果这些绑定属于实现 refreshDataState 函数的控件,则该控件能够对数据状态更改做出反应。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。