当前位置: 首页 > news >正文

WPFdatagrid结合comboBox

在WPF的DataGrid中希望结合使用ComboBox下拉框,达到下拉选择绑定的效果,在实现的过程中,遇到了一些奇怪的问题,因此记录下来。

网上能够查询到的解决方案:

总共有三种ItemSource常见绑定实现方式:
1.ItemSource是静态资源
2.ItemSource是ComboBoxItem类型的内联集合
3.ItemSource是普通数据集合,需要采用ElementStyle显式样式,不然无法正常绑定与显示。

这三种绑定实现方式可自行搜索了解,这里不做过多赘述。

编码绑定方式有两种:
1.直接使用< DataGridComboBoxColumn/>,配置好ItemSource与SelectedItem;
2.使用模板,即使用< DataGridTemplateColumn Header=“xxx”>

遇到的问题

这些方法我都尝试过了,但不知道为什么我实现的出现了以下问题,令我十分困惑。

在这里插入图片描述
现状就是点击了没展开,但是滑动鼠标滚轮又可以正常切换,真是个莫名奇妙的问题。

最终解决方式

  1. SettingViewModel中需要绑定为ItemSource的集合,直接设定为静态类型,原因是普通集合绑定会失败,即使我用了上述中的显式处理,还是没能成功。
    在这里插入图片描述
  2. 采用模板而非DataGridComboBoxColumn,我采用DataGridComboBoxColumn绑定时,仍然出现了点击没展开但滚轮滚动能切换选择的问题。
<DataGridTemplateColumn Header="端口名称"><DataGridTemplateColumn.CellTemplate><DataTemplate><ComboBoxName="cbPortName"Width="120"Height="30"Margin="2"HorizontalAlignment="Left"ItemsSource="{x:Static vm:SettingViewModel.PortNames}"SelectedItem="{Binding PortName, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" /></DataTemplate></DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>

这样,就能正常下拉选择PortNames,并且让选中与datagrid集合下的portname相绑定了。最终效果:
在这里插入图片描述

http://www.lryc.cn/news/187949.html

相关文章:

  • Markdown类图之继承、实现、关联、依赖、组合、聚合总结(十五)
  • @MultipartConfig注解
  • Python并发编程简介
  • WebSocket介绍及部署
  • 自动求导,计算图示意图及pytorch实现
  • 睿伴科创上线了
  • 域名抢注和域名注册
  • 【20】c++设计模式——>组合模式
  • Jetpack:004-如何使用文本组件
  • JVM(八股文)
  • C#WPF标记扩展应用实例
  • 四维曲面如何画?matlab
  • 软件培训测试高级工程师多测师肖sir__html之作业11
  • 详解一典型的反激式开关电源方案
  • AI 大框架基于python来实现基带处理之TensorFlow(信道估计和预测模型,信号解调和解码模型)
  • 阿里云上了新闻联播
  • 算法练习12——跳跃游戏
  • Java架构师系统架构设计服务拆分
  • 通用任务批次程序模板
  • Rust专属开发工具——RustRover发布
  • 数据结构:链表(1)
  • 软件测试之概念篇2(瀑布模型、螺旋模型、增量模型和迭代模型、敏捷模型,V模型、W模型)
  • 【【萌新的SOC学习之重新起航SOC】】
  • ElasticSearch 学习7 集成ik分词器
  • [NewStarCTF 2023 公开赛道] week1
  • ThreeJS-3D教学六-物体位移旋转
  • BC v1.2充电规范
  • 判断一个整数是否回文
  • 【广州华锐互动】车辆零部件检修AR远程指导系统有效提高维修效率和准确性
  • 简单实现接口自动化测试(基于python+unittest)