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 命令的响应逻辑和事件传播范围。

相关推荐
Empty_7778 小时前
编程之python基础
开发语言·python
疯狂吧小飞牛8 小时前
Lua 中的 __index、__newindex、rawget 与 rawset 介绍
开发语言·junit·lua
寻星探路10 小时前
Java EE初阶启程记13---JUC(java.util.concurrent) 的常见类
java·开发语言·java-ee
哲Zheᗜe༘11 小时前
了解学习Python编程之python基础
开发语言·python·学习
落日漫游11 小时前
数据结构笔试核心考点
java·开发语言·算法
寻找华年的锦瑟11 小时前
Qt-配置文件(INI/JSON/XML)
开发语言·qt
HY小海12 小时前
【C++】AVL树实现
开发语言·数据结构·c++
workflower12 小时前
Fundamentals of Architectural Styles and patterns
开发语言·算法·django·bug·结对编程
Roc-xb12 小时前
ModuleNotFoundError: No module named ‘conda_token‘
开发语言·python·conda
人工干智能12 小时前
Python 开发中:`.ipynb`(Jupyter Notebook 文件)和 `.py`(Python 脚本文件)
开发语言·python·jupyter