官术网_书友最值得收藏!

Event aggregator

An event aggregator (also known as publisher/subscriber or Pub-Sub) is a messaging pattern where senders of messages/events, called publishers, do not program the messages to be sent directly to a single/specific receiver, called subscribers, but, instead, categorize published messages into classes without knowledge of which subscribers, if any, there may be. Messages are then funneled through a so-called aggregator and delivered to the subscribers. This approach provides a complete decoupling between the publishers and subscribers while maintaining an effective messaging channel.

Event aggregator implementation within the Xamarin.Forms framework is done via MessagingCenterMessagingCenter exposes a simple API that is composed of two methods for subscribers (that is, subscribe and unsubscribe) and one method for publishers (send).

We can demonstrate the application of the event aggregator pattern by creating a simple event sink for service communication or authentication issues in our application. In this event sink (which will be our subscriber), we can subscribe to error messages that are received from various view-models (given that they all implement the same base type) and alert the user with a friendly dialog:

MessagingCenter.Subscribe<BaseViewModel> (this, "ServiceError", (sender, arg) =>
{
// TODO: Handler the error
});

We would have the following in the event of an unhandled exception on our view-model:

 public void Login()
{
try
{
//TODO: Login
Result = "Successfully Logged In!";
}
catch(Exception ex)
{
MessagingCenter.Send(this, "ServiceError", ex.Message);
}
}
主站蜘蛛池模板: 阜城县| 沿河| 梅河口市| 旬阳县| 石渠县| 正蓝旗| 安阳市| 永寿县| 名山县| 日喀则市| 上蔡县| 河东区| 漳州市| 惠州市| 福建省| 静海县| 大悟县| 阜新| 泊头市| 兴业县| 汽车| 阿巴嘎旗| 谷城县| 海淀区| 桦南县| 屏山县| 泸水县| 桐柏县| 洞口县| 岳西县| 泰来县| 南平市| 儋州市| 绥棱县| 临夏市| 新邵县| 新野县| 清河县| 尚义县| 积石山| 叙永县|