avaloniaui - 如何在 DataGrid 中的 Avalonia Ui 中使用组合框制作列?
问题描述
是否可以在 Avalonia Ui DataGrid 中实现一个带有组合框编辑单元格的列,也就是说,只需打开这个组合框就可以编辑一个单元格,并且用户可以简单地从提供的选项中进行选择?我试图实现这样的 DataGrid,但遇到了问题。我连接了 Nuget Avalonia.DataGrid 库,按照它所说的方式连接了 App.axaml 中的样式。结果,组合框出现在 DataGrid 中,但其中没有下拉菜单,尽管相同的组合框在 DataGrid 之外也能正常工作。这段代码有什么问题?
//ViewModel
public List<int> Test3 {get;set;}
//View Window
<DataGrid Items="{Binding Tests}" SelectionMode="Single">
<DataGrid.Columns>
<DataGridTemplateColumn Width="*" Header="Route" IsReadOnly="False">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<ComboBox x:Name="combo" Items="{Binding Path=DataContext.Test3, RelativeSource={RelativeSource AncestorType={x:Type Window}}}"/>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
</DataGrid.Columns>
</DataGrid>
解决方案
您忘记将属性添加Tests
到您的 ViewModel。
也有条件可能会很好SelectedItem
,但那是断章取义的......
我使用了这段代码:
//ViewModel
public List<int> Test3 { get; set; } = new List<int>(new int [] {1, 2, 3});
public List<int> Tests { get; set; } = new List<int>(new int[] { 1, 2 });
//XAML
<DataGrid Items="{Binding Tests}" SelectionMode="Single">
<DataGrid.Columns>
<DataGridTemplateColumn Width="*" Header="Route" IsReadOnly="False">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<ComboBox x:Name="combo" Items="{Binding Path=DataContext.Test3, RelativeSource={RelativeSource AncestorType={x:Type Window}}}"/>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
</DataGrid.Columns>
</DataGrid>
如果你做了所有这些并且你的绑定工作,但你仍然没有得到我的结果,你需要提供更多的上下文(例如你使用了哪些主题,你运行程序的操作等)。
推荐阅读
- r - 对不平衡面板数据的处理效果
- python - 限制删除 django 模型值的问题
- reactjs - 如何在登录页面上使用 React Router Link?
- python - 更新 JSON 文件的键值
- python - 通过删除 [] 更改 Python 子字符串
- tensorflow - 刚刚从 anaconda 重新安装了 keras-gpu,并收到了关于使用 windows 10 的 tensorflow 的弃用警告
- c++ - 初始化面向对象的数组 C++
- javascript - 如何使用 JS 脚本在同一个文件中运行 mocha
- javascript - 每次数据可用时,如何一次将三个项目附加到一行中?
- grails - 有没有办法用 hasOne 孩子懒惰地获取 GORM 实体?