首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

简单实现DataGrid使用CheckBox选择行

以前写过几个方法实现这个功能,但最终还是选择了不继承DataGrid,所以再重新发布出来。 先显示最终结果,其中左边是错误的例子,右边才是正确的 ?...在DataGrid中使用CheckBox选择行时典型的错误就是CheckBox没有Binding到任何属性上,这样的话当拖动滚动条时CheckBox.IsChecked就会乱掉,如Demo中左边那个DataGrid...其实只要在DataGrid.LoadingRow事件中将CheckBox的DataContext设定为另外一个Object,就不需要牺牲DataGrid的高效能,也不需要改变原有数据的结构。...最终的实现方法是自定义一个包含DataGrid的DataGridTemplateColumn,而不需要重写DataGrid,这样的坏处就是每次调用需要多写一局代码,如果不想这样就继承DataGrid然后把这句代码写进去...在DataGrid.Columns中加入自定义的Column,然后在代码中关联DataGrid和这个Colum,就完成了: DataGrid ItemsSource="{Binding}"

89530
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    深入解析 DataGrid 过滤功能

    默认过滤 把一个IEnumerable数据源绑定到C1DataGrid上,设置CanUserFilter为true,就可以看到默认条件下的过滤结果。...根据不同列的数据类型,C1DataGrid还提供了特殊的过滤器。比如日期类型或者布尔类型的列中,可以选择适合的条件过滤器,如下图所示: ?...行过滤 另外一种基本的过滤功能可通过典型的过滤行来实现。过滤行是由一些文本框组成的固定行,用户可以在改行的文本框中输入过滤条件。...可作为过滤条件的值以选择列表的形式显示,用户可以选择那些值显示,那些不显示,这为拥有唯一或者重复值的列提供了非常有效的过滤方式(例如:类别或类型列)。你可以通过两种方法实现多值过滤功能。...第一种方法是利用C1DataGrid内置的高级过滤特性。只需为Grid添加 一个C1AdvancedFiltersBehavior类,这样就为Grid添加了内置的高级过滤功能,包括多值过滤。

    2.9K70

    jQuery EasyUI 详解

    名称 类型 说明 默认值 columns array datagrid 的 column 的配置对象,更多详细请参见 column 的特性。...默认的 view null 列(Column)的特性 DataGrid 的 Column 是一个数组对象,它的每个元素也是一个数组。数组元素的元素是一个配置对象,它定义了每个列的字段。...load param 加载并显示第一页的行,如果指定 param 参数,它将替换 queryParams 特性。 reload param 重新加载行,就像 load 方法一样,但是保持在当前页。...getRowIndex row 返回指定行的索引,row 参数可以是一个行记录或者一个 id 字段的值。 getSelected none 返回第一个选中的行或者 null。...getSelections none 返回所有选中的行,当没有选中的记录时,将返回空数组。 clearSelections none 清除所有的选择。

    9.2K10

    WPF DataGrid 通过自定义表头模拟首行固定

    一开始,参照了其它界面,这一行还是通过数据行来做,只不过绑定的数据项中有一个特殊的属性来表明这是个特殊行,界面上通过数据模板选择器来自动展现出特别的内容(新增按钮及相关文字,并把其它字段内容隐藏)。...最后就是表格控件 DataGrid 了,使用了上面这些资源,默认使用的是普通表头样式,所以普通列就不用特地指定样式了。...主要就是在原来表头的基础上新增了一行,第一行还是放原来的表头内容(基本就是标题文本),然后第二行就是空出来,给有需要的特殊列留好空间,或者说是与特殊列统一,具体见下图: 特殊表头样式继承于普通表头样式...前面也说过 DataGrid 指定了普通表头样式作为默认的表头样式,所以普通列就不用额外设置了,而且由于内容简单,所以直接使用 Header 属性设置表头内容(列标题)。...关键的是特殊列的表头,首先是指定了表头样式,然后通过 Header 标签来设置内容,内容同样是分为两行,第一行就是列标题内容,第二行通过一个内容控件 ContentControl 将那个加号加载进来。

    2.5K10

    Easyui datagrid combobox输入框非法输入判断与事件总结

    测试环境 jquery-easyui-1.5.3 常见事件 onSelect // 选择下拉列表项时触发的事件 onHidePanel // 收起下拉列表时触发的事件 onChange // commbox...onSelect -> onChange -> onHidePanel; 如果选取项和当前输入框的值一样,仅会触发事件:onHidePanel 2、输入 通过在Combobox输入框中手动输入数据 如果停止输入后的数据和输入前的值不一样...javascript"> var textChanged=false; // 用于判断是否combobox选取、输入的内容是否改变 var rowsSelected=undefined; // 用于记录选取的行...datagrid" title="Row Editing in DataGrid" style="width:1000px;height:auto...附:我早些前的做法,如下,获取输入框的值,然后遍历逗号分隔的每项是否在下拉列表中,是的话停止遍历,进行下一个项的检测,只要有一项不符则判断为非法输入。

    3.5K30

    day51_BOS项目_03

    第一步:由于默认自带的检验规则较少,所以我们需要扩展校验规则,对手机号进行校验     // 扩展校验规则     $(function...的使用方式 数据网格(datagrid)以表格格式显示数据,并为选择、排序、分组和编辑数据提供了丰富的支持。...5、基于datagrid实现取派员分页查询 第一步:修改staff.jsp页面中datagrid的URL地址,访问action     // 取派员信息表格     $('#grid').datagrid...// 获得选中的行         var rows = $("#grid").datagrid("getSelections");         if (rows.length == 0) {             ...的双击行事件的处理函数   onDblClickRow   当用户双击一行时触发,参数包括:     rowIndex:被双击行的索引,从 0 开始     rowData:被双击行对应的记录

    3.4K10

    Newbeecoder.UI新版开源控件库DataGrid使用说明

    用DataGrid控件显示数据和信息的集合。在WPF能自定义外观,单元格,表格头部,字体,颜色等内容。 使用ItemsSource属性进行数据源绑定,绑定任何实现IEnuemerable的数据源。...默认情况下,当用户单击DataGrid中的单元格时会选择整行,如果用户选择多行设置SelectionMode属性。假如不想生成自动列使用AutoGenerateColumns属性设置为false。...GridLinesVisibility使网格线可见、AreRowDetailsFrozen冻结行详细信息。Microsoft Docs对DataGrid每项功能有详细说明。...在样式中有常见的表格选项,如交替行背景和显示/隐藏标题,网格线和滚动条。多个样式和模板属性,通过对ColumnHeaderStyle,CellStyle,RowStyle自定义样式达到设计需求。...> DataGrid> ​

    2.9K30

    【愚公系列】2023年10月 WPF控件专题 DataGrid控件详解

    DataGrid还有许多其他的属性和方法,可以根据需求进行使用。1.属性介绍WPF中DataGrid控件的常见属性如下:AutoGenerateColumns:是否自动生成列,默认为true。...CanUserAddRows:是否允许用户新增行,默认为true。CanUserDeleteRows:是否允许用户删除行,默认为true。...SelectionMode:选择模式,有Single和Extended两种模式可选,默认为Extended。RowHeaderWidth:行头宽度。RowHeight:行高。...AlternatingRowBackground:交替行的背景色。GridLinesVisibility:网格线的可见性,默认为None。ItemsSource:数据源。...数据编辑:DataGrid控件可以支持数据的编辑,包括单元格编辑、行编辑和列编辑等方式,方便用户对数据进行修改和更新。

    1.2K00

    WPF DataGrid 如何将被选中行带到视野中

    而还有一种情况,我们可能在业务逻辑中,由程序自己选中了某一行,如果这一行当前不在用户界面的可视区(换句话说也就是滚动条没有滚到那个位置),那么我们如何将其带到用户的视野中呢?...使用的还是之前用过的 DataGrid 的 Demo 程序(在《WPF DataGrid 通过自定义表头模拟首行固定》和《WPF 触屏事件后触发鼠标事件的问题及 DataGrid 误触问题》中用过),加了一个可以填写要选中的行号的文本框...时需要设置 EnableRowVirtualization="False"(默认为 true): 使用时只要在行样式中应用这个附加属性即可: 注意引入命名空间: 效果如下(动图): 方法二...类似于这个帖子的情况《WPF 开启行虚拟化的时候,行选择功能不正常,求解决方案》(https://bbs.csdn.net/topics/392666509): 所以如果因为数据量比较大必须开启行虚拟化时...方法二则是需要在 ViewModel 和页面后台编写代码,通过事件来触发相关操作,不过可以支持行虚拟化。大家可以依据实际情况选择使用,如果有更好的方法,欢迎交流。

    1.9K10
    领券