我们知道如果要设置window.Showdialog()的返回值,需要设置window.DialogResult属性。但是设置window.DialogResult属性会自动触发close,如果window.DialogResult属性会触发Window_OnClosing事件
private void BtnCancel_Click(object sender, RoutedEventArgs e)
{
DialogResult = false;
}
private void Window_OnClosing(object sender, CancelEventArgs e)
{
e.Cancel = true;
}
如果Window_OnClosing中设置了e.Cancel = true,那么DialogResult会无法赋值成功,说明给DialogResult赋值前会先Close,如果Close失败会跳过DialogResult赋值过程。
为了解决上面的问题,可以使用自定义属性覆盖掉原先的DialogResult属性,然后使用Hide()替换Window_OnClosing里面的e.Cancel = true操作。
public new bool DialogResult { get; set; }
当然由于是自定义的属性,所以window.Showdialog()的返回值不会改变,做判断时可以
dialogRestart.ShowDialog();
if (dialogRestart.DialogResult)
如果弹窗是静态单例,那么不要关闭按钮直接Hide,应该放在Window_OnClosing事件中e.Cancel = true和Hide()。因为如果弹窗被Alt+F4的方式强制关闭,那么该窗体会触发Close,下次就无法Show处理。所以要么就不设置单例,要么就调整Window_OnClosing事件不让关闭,改成Hide
在WPF中,设置Window.DialogResult会自动关闭窗口并触发Window_OnClosing事件。如果在Window_OnClosing中阻止关闭(e.Cancel=true),DialogResult可能无法赋值。一种解决方案是创建自定义DialogResult属性并使用Hide()代替阻止关闭。对于静态单例弹窗,应考虑在Window_OnClosing中隐藏窗口,以防被强制关闭后无法再次显示。
1392

被折叠的 条评论
为什么被折叠?



