为什么我无法将Command绑定到按钮?

时间:2013-06-03 13:46:11

标签: c# silverlight windows-phone-7 mvvm command

我在Windows Phone 7.5及更高版本上处理项目目标。

我有什么
列表框

<ListBox    HorizontalAlignment="Left" 
        VerticalAlignment="Top" 
        SelectedItem="{Binding singleFavListItem, Mode=TwoWay}"
        ItemTemplate="{StaticResource userFavBoardListItemTemplate}"
        ItemsSource="{Binding userfavboardlist}" 
        ScrollViewer.VerticalScrollBarVisibility="Disabled" Margin="12,0,0,12"/>

的ItemTemplate

<DataTemplate x:Key="userFavBoardListItemTemplate">
    <Grid>
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="70*"/>
            <ColumnDefinition Width="30*"/>
        </Grid.ColumnDefinitions>
        <TextBlock  HorizontalAlignment="Left" 
            TextWrapping="Wrap" 
            Text="{Binding boardName}" 
            VerticalAlignment="Center" 
            FontSize="{StaticResource PhoneFontSizeMedium}" 
            Foreground="{StaticResource TitleColor}"/>
        <Button Command="{Binding quitBoardCommand}"
                CommandParameter="{Binding boardUrl}"
                Content="Quit" 
        HorizontalAlignment="Left" 
        VerticalAlignment="Top" 
        Grid.Column="1"
        FontSize="{StaticResource PhoneFontSizeSmall}" 
        BorderBrush="{StaticResource DateArticalCategoryColor}" 
        Foreground="{StaticResource DateArticalCategoryColor}">
     </Button>
    </Grid>
</DataTemplate>

视图模型

public MyFavListViewModel()
{
    this._quitBoardCommand = new DelegateCommand(this.quitBoardAction);
}
private ICommand _quitBoardCommand;
public ICommand quitBoardCommand
{
    get
    {
        return this._quitBoardCommand;
    }
}
private void quitBoardAction(object p)
{
    //my business logic here
}

错误
我在OutPut窗口中发现了一个错误:

  

'xicihutong.Model.UserFavBoardListRawData'(HashCode = 55845053)。   BindingExpression:Path ='quitBoardCommand'   的DataItem = 'xicihutong.Model.UserFavBoardListRawData'   (的HashCode = 55845053);目标元素是   'System.Windows.Controls.Button'(Name ='');目标属性是   'Command'(输入'System.Windows.Input.ICommand')..

问题是什么
让我感到困惑的是,当我点击按钮时,quitBoardCommand永远不会被触发?似乎我无法将Command绑定到按钮,DelegateCommand部分是正确的,因为我可以使用它来绑定其他页面中的命令。 ListBox的SelectedItem也正常工作。

为什么我不能绑定这个?

2 个答案:

答案 0 :(得分:1)

您需要引用DataContext的{​​{1}}来绑定您的命令。要解决此问题,请为您的ListBox命名,然后引用命令属性

ListBox

答案 1 :(得分:0)

你能试试这段代码吗?您不要忘记更改“datacontext”名称。

<DataTemplate x:Key="userFavBoardListItemTemplate">
    <Grid>
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="70*"/>
            <ColumnDefinition Width="30*"/>
        </Grid.ColumnDefinitions>
        <TextBlock  HorizontalAlignment="Left" 
            TextWrapping="Wrap" 
            Text="{Binding boardName}" 
            VerticalAlignment="Center" 
            FontSize="{StaticResource PhoneFontSizeMedium}" 
            Foreground="{StaticResource TitleColor}"/>
        <Button Command="{Path=quitBoardCommand,Source={StaticResource datacontext}}"
                CommandParameter="{Binding boardUrl}"
                Content="Quit" 
        HorizontalAlignment="Left" 
        VerticalAlignment="Top" 
        Grid.Column="1"
        FontSize="{StaticResource PhoneFontSizeSmall}" 
        BorderBrush="{StaticResource DateArticalCategoryColor}" 
        Foreground="{StaticResource DateArticalCategoryColor}">
     </Button>
    </Grid>
</DataTemplate>