2

我在ListBoxItem. 所以当我拿着一个项目时,它会直接进入函数,但它会在被触发两次时出现。

private async void OutersAndContactInTel_Holding(object sender, HoldingRoutedEventArgs e)
{
    try
    {
        FrameworkElement element = (FrameworkElement)e.OriginalSource;
        if (element.DataContext != null && element.DataContext is Contact)
        {
            Contact selectedContact = (ImOutContact)element.DataContext;
            if (selectedContact.IsOuter)
            {
                MessageDialog msgToAddContact = new MessageDialog("Voulez-vous vraiment suivre " + selectedContact.Pseudo + " ?");
                msgToAddContact.Commands.Add(new UICommand("Oui", (UICommandInvokedHandler) =>
                {
                    AddContactProcess(selectedContact);
                }));
                msgToAddContact.Commands.Add(new UICommand("Non"));

                this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () => msgToAddContact.ShowAsync());
            }
            else
            {
                MessageDialog msgToInviteContact = new MessageDialog("Envoyez une invitation à  l'utilisation de l'application par sms à " + selectedContact.NomPrenom + " ?");
                msgToInviteContact.Commands.Add(new UICommand("Oui", (UICommandInvokedHandler) =>
                {
                    SendSmsToInvite(selectedContact);
                }));
                msgToInviteContact.Commands.Add(new UICommand("Non"));
                await msgToInviteContact.ShowAsync();
            }
        }
    }
    catch (Exception ex)
    {
        MessageDialog errorMessage = new MessageDialog(CustomDialogMessage.getMessageContent(CustomDialogMessage.ERROR_MESSAGE));
        this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () => errorMessage.ShowAsync());
    }
}

当我在该函数的末尾显示一个MessageDialog msgToAddContact时,它被触发了两次,它也MessageDialog显示了两次。

如果第一个MessageBox.showAsync没有完成,它会崩溃,因为不可能同时显示多个MessageDialog

有谁知道如何阻止举行活动的第二次执行?

提前致谢!

4

1 回答 1

10

我刚刚发现为什么它会多次触发。像 Holding 或 SelectionChanged 这样的事件是具有不同状态的事件。在我的情况下,举行事件有 3 个状态:开始完成取消。不同的状态如下进行。当我一次持有一个元素时,该事件的状态为start,当 eventHandler 中的整个函数完成时,第二次触发持有事件,状态为completed,如果用户取消事件也是如此。

Msft 在这里解释得很好:EventHandler

为了避免在每个状态下执行相同的代码,只需在关键代码的开头添加一个条件,该条件将只执行一次。

我的代码实际上看起来就像你可以与我的第一篇文章进行比较:

private async void OutersAndContactInTel_Holding(object sender, HoldingRoutedEventArgs e)
{
    try
    {
        FrameworkElement element = (FrameworkElement)e.OriginalSource;
        if (element.DataContext != null && element.DataContext is Contact && e.HoldingState == Windows.UI.Input.HoldingState.Started)
        {
            Contact selectedContact = (ImOutContact)element.DataContext;
            if (selectedContact.IsOuter)
            {
                MessageDialog msgToAddContact = new MessageDialog("Voulez-vous vraiment suivre " + selectedContact.Pseudo + " ?");
                msgToAddContact.Commands.Add(new UICommand("Oui", (UICommandInvokedHandler) =>
                {
                    AddContactProcess(selectedContact);
                }));
                msgToAddContact.Commands.Add(new UICommand("Non"));

                this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () => msgToAddContact.ShowAsync());
            }
            else
            {
                MessageDialog msgToInviteContact = new MessageDialog("Envoyez une invitation à  l'utilisation de l'application par sms à " + selectedContact.NomPrenom + " ?");
                msgToInviteContact.Commands.Add(new UICommand("Oui", (UICommandInvokedHandler) =>
                {
                    SendSmsToInvite(selectedContact);
                }));
                msgToInviteContact.Commands.Add(new UICommand("Non"));
                await msgToInviteContact.ShowAsync();
            }
        }
    }
    catch (Exception ex)
    {
        MessageDialog errorMessage = new MessageDialog(CustomDialogMessage.getMessageContent(CustomDialogMessage.ERROR_MESSAGE));
        this.Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () => errorMessage.ShowAsync());
    }
}
于 2015-02-01T17:09:05.430 回答