11.WPF 的命令处理事件--参数介绍

在 WPF 的命令处理事件 中,OnCommandHandled(object s, ExecutedRoutedEventArgs e) 方法的参数作用如下:

1. object s

  • 含义 :事件源对象(Sender),即触发命令的控件(如 ButtonMenuItem 等)。
  • 作用
    • 标识哪个控件触发了命令事件(例如用户点击了某个按钮)。
    • 可通过类型转换获取具体控件实例(如 Button btn = s as Button;)。
  • 示例场景
    若多个按钮共用同一命令处理逻辑,可通过 s 区分具体是哪个按钮触发了事件。

2. ExecutedRoutedEventArgs e

  • 含义:命令执行的事件参数,包含命令相关的核心信息。
  • 关键属性
    • e.Command
      获取被执行的命令对象(如 ApplicationCommands.Copy)。

      csharp 复制代码
      if (e.Command == ApplicationCommands.Paste) { ... }
    • e.Parameter
      获取命令传递的参数(通过 CommandParameter 绑定设置的值)。

      csharp 复制代码
      var data = e.Parameter as string; // 获取参数
    • e.Source
      获取实际触发命令的原始控件(可能与 s 不同,尤其在事件路由中)。

    • e.Handled
      关键属性 :布尔值,默认为 false

      • 设置为 true(如代码中 e.Handled = true;)会停止事件路由,阻止事件继续向上或向下传递。
      • 未设置时,事件会沿 WPF 视觉树冒泡/隧道传播。

代码行为解释

csharp 复制代码
e.Handled = true; // 阻止继续路由
  • 作用
    标记该命令事件"已处理",WPF 事件系统将不再将此命令事件传递给其他控件(如父容器或子元素)。
  • 典型场景
    在自定义命令处理中,若已完全处理命令逻辑,可设置 e.Handled=true 避免其他控件重复响应。

总结

参数 类型 作用
s object 事件触发源控件(可通过类型转换操作具体控件)。
e ExecutedRoutedEventArgs 提供命令详情(如具体命令、参数),并通过 Handled 控制事件路由行为。

通过合理使用这两个参数,可精准控制 WPF 命令的响应逻辑和事件传播范围。

相关推荐
晨星shine2 小时前
GC、Dispose、Unmanaged Resource 和 Managed Resource
后端·c#
用户2986985301410 小时前
.NET 文档自动化:Spire.Doc 设置奇偶页页眉/页脚的最佳实践
后端·c#·.net
用户36674625267411 小时前
接口文档汇总 - 2.设备状态管理
c#
用户36674625267411 小时前
接口文档汇总 - 3.PLC通信管理
c#
Ray Liang1 天前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
Scout-leaf4 天前
WPF新手村教程(三)—— 路由事件
c#·wpf
用户298698530144 天前
程序员效率工具:Spire.Doc如何助你一键搞定Word表格排版
后端·c#·.net
mudtools5 天前
搭建一套.net下能落地的飞书考勤系统
后端·c#·.net
玩泥巴的6 天前
搭建一套.net下能落地的飞书考勤系统
c#·.net·二次开发·飞书
唐宋元明清21886 天前
.NET 本地Db数据库-技术方案选型
windows·c#