我有一个从ItemsControl继承的自定义用户控件。通过它的ItemTemplate,它从一个ObservableCollection为每个附加的ViewModel创建一个ChildControl。
public class ChildControl : FrameworkElement
{
public static readonly RoutedEvent CreatedEvent = EventManager.RegisterRoutedEvent(
nameof(Created),
RoutingStrategy.Bubble,
typeof(RoutedEventHandler),
typeof(ChildControl));
public static readonly RoutedEvent RemovedEvent = EventManager.RegisterRoutedEvent(
nameof(Removed),
RoutingStrategy.Bubble,
typeof(RoutedEventHandler),
typeof(ChildControl));
public ChildControl
{
Loaded += OnLoaded;
Unloaded += OnUnloaded;
}
public event RoutedEventHandler Created
{
add => AddHandler(CreatedEvent, value);
remove => RemoveHandler(CreatedEvent, value);
}
public event RoutedEventHandler Removed
{
add => AddHandler(RemovedEvent, value);
remove => RemoveHandler(RemovedEvent, value);
}
private void OnLoaded(object sender, RoutedEventArgs e)
{
RaiseEvent(new RoutedEventArgs(CreatedEvent));
}
private void OnUnloaded(object sender, RoutedEventArgs e)
{
RaiseEvent(new RoutedEventArgs(RemovedEvent));
}
}和CustomItemsControl
public class CustomItemsControl : ItemsControl
{
public CustomItemsControl()
{
AddHandler(ChildControl.CreatedEvent, new RoutedEventHandler(OnCreatedEvent));
AddHandler(ChildControl.RemovedEvent, new RoutedEventHandler(OnRemovedEvent));
}
private void OnCreatedEvent(object sender, RoutedEventArgs e)
{
// stuff
}
private void OnRemovedEvent(object sender, RoutedEventArgs e)
{
// stuff
}
}除了RemovedEvent处理程序之外,一切都运行得很好。当事件在ChildControl的卸载事件处理程序中引发时,它不会被CustomItemsControl捕获。但是,当调用RemovedEvent (比如在加载的事件处理程序中)时,它将被CustomItemsControl捕获。所以它证明了一切都很好。
我是否做错了什么,或者这是否意味着从卸载事件处理程序中调用的RoutedEvents没有被设计冒泡?
发布于 2020-10-09 09:41:41
那东西不见了。
但你还是希望能听到。
重新考虑卸载的事件。想想发生了什么。
“当元素被从加载元素的元素树中删除时发生。”
它不见了。
就像不在那里一样。
不是在任何视觉树里,也不是在任何东西上。
因为它是从UI卸载的。
来自它的路由事件不能气泡或隧道或任何涉及视觉树的内容。因为uielement已经不在那棵树上了。
您需要做的是首先引发一个自定义路由事件,然后卸载您的控件。也许使用完全不同的方法是更好的方法。示例包括: prism、事件聚合器或mvvmlight信使,或者将引用从父传递到子引用,这样它就可以直接调用方法。
https://stackoverflow.com/questions/64277211
复制相似问题