我已經嘗試了 Stackoverflow 上的幾乎所有解決方案我不明白為什么我的 datagrid 內按鈕的系結陳述句沒有在 ViewModel 中命中該屬性。這是我的資料網格:
<DataGridTemplateColumn Header="Delete">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<Button Command="{Binding DataContext.DeleteButton, RelativeSource={RelativeSource AncestorType=UserControl}}">Delete</Button>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
這是我在 VeiwModel 中的代碼:
private ICommand _delete;
public ICommand DeleteButton
{
get
{
if (_delete == null)
{
_delete = new UserCommand(DeleteItemExecute, CanDeleteItemExecute);
}
return _delete;
}
}
uj5u.com熱心網友回復:
我做同樣的事情,但另一種方式:
查看代碼:
<Button Click="DeleteObject">
<Image Source="../img/image_delete.png" Width="20" Height="20"/>
</Button>
然后在我的模型上:
private void DeleteObject(object sender, RoutedEventArgs e)
{
Button button = sender as Button;
Object selectedObject = button.DataContext as Object;
}
uj5u.com熱心網友回復:
在我的參考中添加了“名稱”
<Page x:Class="InventoryManagementWPF.Views.InventoryPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:local="clr-namespace:InventoryManagementWPF.Views"
xmlns:viewmodel ="clr-namespace:InventoryManagementWPF.ViewModel"
mc:Ignorable="d"
d:DesignHeight="450" d:DesignWidth="800"
Title="InventoryPage"
------> x:Name="_window"> <------------- Added this change only
<Button Command="{Binding DataContext.DeleteButton, ElementName=_window}" CommandParameter ="{Binding}">Delete</Button>
其他一切都是一樣的。這對我有用。我在這里找到了解決方案
uj5u.com熱心網友回復:
您可以在不指定連接器名稱的情況下執行以下操作。您可以在RelativeSource 此處找到有關使用的詳細資訊。
Xaml 代碼
<DataGrid ItemsSource="{Binding DataItemCollection}" AutoGenerateColumns="False" CanUserAddRows="False">
<DataGrid.Columns>
<DataGridTextColumn Header="Item - 1" Binding="{Binding Item1}"/>
<DataGridTextColumn Header="Item - 2" Binding="{Binding Item2}"/>
<DataGridTextColumn Header="Item - 3" Binding="{Binding Item3}"/>
<DataGridTemplateColumn Header="Delete">
<DataGridTemplateColumn.CellTemplate>
<DataTemplate>
<Button Command="{Binding RelativeSource={RelativeSource AncestorType={x:Type DataGrid}}, Path=DataContext.DeleteCommand}">Delete</Button>
</DataTemplate>
</DataGridTemplateColumn.CellTemplate>
</DataGridTemplateColumn>
</DataGrid.Columns>
</DataGrid>
視圖模式代碼
class MainWindowViewModel
{
public RelayCommand DeleteCommand { get; set; }
private ObservableCollection<DataItem> _dataItemCollection = new ObservableCollection<DataItem>();
public ObservableCollection<DataItem> DataItemCollection
{
get { return _dataItemCollection; }
set { _dataItemCollection = value; }
}
public MainWindowViewModel()
{
DataItemCollection.Add(new DataItem { Item1 = "Item - 1", Item2 = "Item - 2", Item3 = "Item - 3" });
DeleteCommand = new RelayCommand(Delete);
}
void Delete(object param)
{
Console.WriteLine("Delete Click");
}
}
中繼命令
public class RelayCommand : ICommand
{
#region Fields
readonly Action<object> _execute;
readonly Predicate<object> _canExecute;
#endregion
#region Constructors
public RelayCommand(Action<object> execute) : this(execute, null) { }
public RelayCommand(Action<object> execute, Predicate<object> canExecute)
{
if (execute == null)
throw new ArgumentNullException("execute");
_execute = execute;
_canExecute = canExecute;
}
#endregion
#region ICommand Members
public bool CanExecute(object parameter)
{
return _canExecute == null ? true : _canExecute(parameter);
}
public event EventHandler CanExecuteChanged
{
add { CommandManager.RequerySuggested = value; }
remove { CommandManager.RequerySuggested -= value; }
}
public void Execute(object parameter)
{
_execute(parameter);
}
#endregion
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/313955.html
