首页 文章

在AutoCompleteBox中,不会为'enter'触发KeyDown事件

提问于
浏览
3

我在ASP.NET Web应用程序中使用Silverlight用户控件 . 用户控件有几个自动完成框,似乎在触发其他键时,回车键永远不会触发其中任何一个的keydown事件 .

我假设自动填充框必须以不同的方式处理回车键,可能是为了从列表中选择一个项目 . - 因此它适用于简单的文本框 .

我正在考虑在新的派生控件中覆盖eventhandler ...

你们有没有为此找到解决方案?

4 回答

  • 2

    Joe White是正确的,有些控件自己处理关键事件,这会将它们屏蔽到更高级别的控件 . 如果您查看Reflector中的AutoCompleteBox,您会看到Enter,Escape和F4都会导致某些事情发生并标记为e.Handled = true .

    不幸的是,Silverlight世界中不存在PreviewKeyDown .

    我能够阻止控件响应和捕获这些键事件的一种方法是通过继承控件并重写OnKeyDown方法 . 这样的事情可以让你控制控件是否对关键事件做出反应:

    public class MyAutoCompleteBox : AutoCompleteBox
    {
        public static readonly DependencyProperty HandleKeyEventsProperty = DependencyProperty.Register(
            "HandleKeyEvents",
            typeof(bool),
            typeof(MyAutoCompleteBox),
            new PropertyMetadata(true));
    
        public bool HandleKeyEvents
        {
            get { return (bool)GetValue(HandleKeyEventsProperty); }
            set { SetValue(HandleKeyEventsProperty, value); }
        }
    
        protected override void OnKeyDown(KeyEventArgs e)
        {
            if (this.HandleKeyEvents)
            {
                base.OnKeyDown(e);
            }
        }
    }
    

    然后,您可以使用XAML中的HandleKeyEvents属性来禁止控件处理它们:

    <local:MyAutoCompleteBox HandleKeyEvents="False"/>
    

    这种类型的东西会阻止基本AutoCompleteBox标记e.Handled = true并允许事件冒泡,以便你的更高级别的控件可以用它做其他事情 . 如果您想要阻止其他KeyDown事件(除了Enter)之外,您可以更加具体地处理哪些键被处理 .

  • 4

    小学生错误 - 我专注于KeyDown,我忘记了我可以使用KeyUp代替...... :)它仍然没有回答我的orignal问题,但至少我可以继续前进!

  • 0

    我不知道自动完成框,但我知道一些WPF控件(也可能是一些Silverlight控件)自己处理一些键,并将它们标记为Handled . 所以通常你不会看到那些事件 .

    最简单的解决方案是挂钩PreviewKeyDown . 这几乎就是它的用途 .

  • 0

    我基于Dan Auclair的解决方案,简化它以删除依赖属性并更改逻辑以反映我认为您正在寻找的用例 .

    public class MyAutoCompleteBox : AutoCompleteBox
    {
        protected override void OnKeyDown(KeyEventArgs e)
        {
            if (e.Key == Key.Enter && !IsDropDownOpen)
            {
                e.Handled = false;
            }
            else
            {
                base.OnKeyDown(e);
            }
        }
    }
    

相关问题