原文:示例:WPF实现ApplicationCommands.Delete的TextBox

目的:通过模仿TextBox中Ctrl+C等快捷键原理来了解CommandBindings实现原理,可以通过此示例了解ApplicationCommands.Copy在TextBox中实现的原理

一、定义一个自己的MyCommands.Delete


  1. class MyCommands
  2. {
  3. public static RoutedUICommand DeleteCommand = new RoutedUICommand();
  4. }

二、定义一个TextBoxControl控件来封装TextBox并包含Ctrl+D删除文本内容

XAML部分:


  1. <UserControl.InputBindings>
  2. <KeyBinding Command="local:MyCommands.DeleteCommand" Key="D" Modifiers="Ctrl"/>
  3. </UserControl.InputBindings>
  4. <Grid>
  5. <StackPanel Orientation="Horizontal">
  6. <TextBlock Text="按住Ctrl+D删除文件内容" Width="200"/>
  7. <TextBox x:Name="tb_content" Text="请输入文本" Width="200"/>
  8. </StackPanel>
  9. </Grid>

CS部分:


  1. private void CommandBinding_Executed(object sender, ExecutedRoutedEventArgs e)
  2. {
  3. this.tb_content.Text = string.Empty;
  4. }
  5. private void CommandBinding_CanExecute(object sender, CanExecuteRoutedEventArgs e)
  6. {
  7. e.CanExecute = !string.IsNullOrEmpty(this.tb_content.Text);
  8. }

此时的TextBoxControl即可实现Ctrl+D删除文本中内容

三、同AppliactionCommands一样,MyCommands也可以在外部调用并动态更新控件IsEnbled

定义一个MainWindow放置TextBoxControl并定义按钮绑定自定义的MyCommand.DeleteCommand和系统中ApplicationCommands.Copy


  1. <Grid>
  2. <StackPanel HorizontalAlignment="Center" VerticalAlignment="Center">
  3. <Menu>
  4. <MenuItem Header="删除" Command="local:MyCommands.DeleteCommand"/>
  5. <MenuItem Header="剪切" Command="ApplicationCommands.Copy"/>
  6. </Menu>
  7. <local:TextBoxControl x:Name="tb"/>
  8. <ToolBar>
  9. <Button Content="删除" Command="local:MyCommands.DeleteCommand"/>
  10. <Button Content="剪切" Command="ApplicationCommands.Copy"/>
  11. </ToolBar>
  12. </StackPanel>
  13. </Grid>

通过示例可以看到自定义的MyCommands和ApplicationCommands中效果一致

效果如下:(剪切实际上是复制,不必多想,很单纯的文本写错了)

值得注意的需要通过1、menu item 2、toolbar 3、shortcut中使用

如果要用Button等其他控件需要设置CommandTarget

            <Button Content="删除"  Command="local:MyCommands.DeleteCommand" CommandTarget="{Binding ElementName=tb}"/>

示例:WPF实现ApplicationCommands.Delete的TextBox的更多相关文章

  1. WPF自定义控件与样式(3)-TextBox & RichTextBox & PasswordBox样式、水印、Label标签、功能扩展

    一.前言.预览 申明:WPF自定义控件与样式是一个系列文章,前后是有些关联的,但大多是按照由简到繁的顺序逐步发布的等,若有不明白的地方可以参考本系列前面的文章,文末附有部分文章链接. 本文主要是对文本 ...

  2. 【转】WPF自定义控件与样式(3)-TextBox & RichTextBox & PasswordBox样式、水印、Label标签、功能扩展

    一.前言.预览 申明:WPF自定义控件与样式是一个系列文章,前后是有些关联的,但大多是按照由简到繁的顺序逐步发布的等. 本文主要是对文本输入控件进行样式开发,及相关扩展功能开发,主要内容包括: 基本文 ...

  3. WPF 实现带标题的TextBox

    这篇博客将分享在WPF中如何创建一个带Title的TextBox.首先请看一下最终的效果, 实现思路:使用TextBlock+TextBox来实现,TextBlock用来显示Title. 实现代码, ...

  4. WPF自定义控件(二)——TextBox

    和之前一样,先来看看效果: 这个TextBox可设置水印,可设置必填和正则表达式验证. 验证?没错,就是验证! 就是在输入完成后,控件一旦失去焦点就会自动验证!会根据我开放出来的“是否可以为空”属性进 ...

  5. WPF DataGrid列设置为TextBox控件的相关绑定

    在wpf的DataGrid控件中,某一列的数据模板为TextBox控件的话,绑定Text="{Binding TxtSn, UpdateSourceTrigger=PropertyChang ...

  6. 基于WPF系统框架设计(7)-TextBox/PasswordBox在ViewModel中支持回车命令

    应用场景 我现在做一个系统登录功能,要求在PasswordBox上输完密码后回车,能够响应Enter事件,并执行ViewModel中对应的方法.如果登录成功则隐藏当前窗口显示主窗体,登录失败则焦点返回 ...

  7. WPF中Popup上的textbox无法切换到中文输入法

    As Marco Zhou has said in the msdn forum (http://social.msdn.microsoft.com/Forums/en-US/wpf/thread/b ...

  8. 【求助】WPF 在XP下 有的Textbox光标会消失

    最近做个项目,一直有一个问题没有解决,就是在XP下,有的Textbox里在文本框里没有东西的时候,会没有光标.不同的XP机器,失去光标的Textbox也不一样. 各位大师看下面的三张图,当Textbo ...

  9. [WPF系列]-高级部分 Shadowed TextBox

    Download Solution ShadowedTextBoxExample.zip (70.3 KB) Usage <local:ShadowedTextBox Label="F ...

随机推荐

  1. terminator

    terminator 能够实现linux 终端的分屏显示. 安装 sudo add-apt-repository ppa:gnome-terminator sudoapt-get update sud ...

  2. mapping 映射

    es的映射就相当于编程语言中给变量定义类型,定义后的变量使用起来更高效,未定义的变量相较于定义的性能肯定是不如的.所以需要掌握es映射. 未定义映射es会对提供的数据进行类型猜测,如果对自动判断的类型 ...

  3. Linux的httpd服务搭建

    在服务搭建前,还要了解一下httpd的日志. 日志有助有工作人员,查看服务器出错状况,更能统计数据分析网页运行情况. PV和UV两大分析 PV  Page View 页面访问量 UV  User Vi ...

  4. Python多线程采集百度相关搜索关键词

    百度相关搜索关键词抓取,读取txt关键词,导出txt关键词 #百度相关搜索关键词抓取,读取txt关键词,导出txt关键词   # -*- coding=utf-8 -*- import request ...

  5. fiddler常用功能

    原理 Fiddler是一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的http通讯,设置断点,查看所有的“进出”Fiddler的数据(cookie,html,js,css等). ...

  6. mobx 学习笔记

    Mobx 笔记 Mobx 三板斧,observable.observer.action. observable: 通过 observable(state) 定义组件的状态,包装后的状态是一个可观察数据 ...

  7. vue大文件上传控件选哪个好?

    需求: 项目要支持大文件上传功能,经过讨论,初步将文件上传大小控制在20G内,因此自己需要在项目中进行文件上传部分的调整和配置,自己将大小都以20G来进行限制. PC端全平台支持,要求支持Window ...

  8. Oracle EBS11i的下载

    1.登陆Oracle eDelivery https://edelivery.oracle.com/osdc/faces/Home.jspx 2.需要账号登录才能进行下载 chaomu@css.com ...

  9. 网络协议 10 - Socket 编程(上)

    前面一直在说各种协议,偏理论方面的知识,这次咱们就来认识下基于 TCP 和 UDP 协议这些理论知识的 Socket 编程.     说 TCP 和 UDP 的时候,我们是分成客户端和服务端来认识的, ...

  10. 洛谷 P2615 神奇的幻方

    传送门 I'm here! 思路 这个题,我们可以直接去模拟,因为范围很小,且\(N\)都是奇数 直接构造一个矩阵,初始值都为\(0\),然后\(while\)循环,根据题目给出的\(4\)个条件进行 ...