2015-11-01 73 views
2

我建立一個使用MVVM的應用程序,我試圖命令綁定到所看到本教程的按鈕:無法將命令綁定到一個HyperlinkBut​​ton(的Windows Phone 8.1)

https://channel9.msdn.com/Series/Windows-Phone-8-1-Development-for-Absolute-Beginners/Part-24-Binding-to-Commands-and-CommandParameters

然而,我無法使綁定工作 - 當我單擊HyperlinkBut​​ton並且我在Execute方法的開頭放置的斷點不會觸發時,沒有任何反應。

這裏是我的ViewModel:

public class ArticleListViewModel 
{ 
    public IEnumerable<ArticleItem> Items { get; set; } 

    public async Task PopulateArticles() 
    { 
     // ... 
    } 
} 


public class ArticleItem 
{ 
    public ArticleItem() 
    { 
     OpenLinkCommand = new OpenArticleLinkCommand(); 
    } 

    public ICommand OpenLinkCommand; 

    public string Url { get; set; } 

    public string Title { get; set; } 
} 

OpenArticleLinkCommand.cs:

public class OpenArticleLinkCommand : ICommand 
{ 
    public bool CanExecute(object parameter) 
    { 
     return true; 
    } 

    public event EventHandler CanExecuteChanged; 

    public async void Execute(object parameter) 
    { 
     var article = parameter as ArticleItem; 

     if (article != null) 
     { 
      var success = await Launcher.LaunchUriAsync(new Uri(article.Url)); 

      //TODO: handle success/fail 
     } 
    } 
} 

這裏是我查看樣子:

<UserControl 
    x:Class="LTNewsFeed.Views.ArticleItemView" 
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
    xmlns:local="using:LTNewsFeed.Views" 
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
    mc:Ignorable="d" 
    d:DesignHeight="300" 
    d:DesignWidth="400"> 


    <ListBox ItemsSource="{Binding}" x:Name="mainListBox"> 
     <ListBox.ItemTemplate> 
      <DataTemplate> 
       <StackPanel Orientation="Horizontal"> 

        <HyperlinkButton x:Name="Title" 
            Content="{Binding Path=Title, Mode=OneWay}" 
            Command="{Binding OpenLinkCommand}" 
            Grid.Column="0"/> 

       </StackPanel> 
      </DataTemplate> 
     </ListBox.ItemTemplate> 
    </ListBox> 

</UserControl> 

主要Page.xaml:

<Page 
    x:Class="LTNewsFeed.MainPage" 
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
    xmlns:local="using:LTNewsFeed" 
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
    xmlns:views="using:LTNewsFeed.Views" 
    xmlns:src="using:LTNewsFeed" 
    mc:Ignorable="d" 
    Background="{ThemeResource ApplicationPageBackgroundThemeBrush}"> 

    <Grid> 
     <views:ArticleItemView x:Name="ItemsOnPage" /> 
    </Grid> 
</Page> 

我填充視圖模型項集合在MainPage.xaml.cs:

protected override async void OnNavigatedTo(NavigationEventArgs e) 
    { 
     base.OnNavigatedTo(e); 

     await viewModel.PopulateArticles(); 

     ItemsOnPage.DataContext = viewModel.Items; 
    } 

事情我已經沒有成功的嘗試:

  • 引用了作爲建議DataContext並指定ElementNamethis answer
  • 將HyperlinkBut​​ton更改爲簡單按鈕。
  • OpenArticleLinkCommand移動到與我的ArticleItem模型相同的文件中,以防命名空間無法識別。
  • 在Google和StackOverflow上瀏覽類似的問題 - 在我看來,我所做的一切都與示例中的相同。

任何幫助指向我在正確的方向,或描述如何我可以調試這種東西將不勝感激。

+0

您是否看到列表框中的項目? –

+0

我懷疑你的演員在執行功能失敗 –

回答

1

儘管聽起來很奇怪,但綁定僅適用於屬性。所以,你需要暴露你的命令作爲一個屬性,而不是一個領域:

public ICommand OpenLinkCommand { get; set; } 

你可以通過查看Visual Studio中的輸出面板,其中,在執行時被顯示錯誤消息已經注意到了這一點

Error: BindingExpression path error: 'OpenLinkCommand' property not found

請注意,您將立即遇到另一個問題:您希望爲您的命令指定一個參數,但您忘記設置一個參數。由於您顯然期待ArticleItem作爲參數,因此您可以簡單地綁定datacontext:

<HyperlinkButton x:Name="Title" 
    Content="{Binding Path=Title, Mode=OneWay}" 
    Command="{Binding OpenLinkCommand}" 
    CommandParameter="{Binding}" 
    Grid.Column="0"/> 
+0

謝謝!這一直使我瘋狂,而且我沒有注意到這個命令必須作爲一個財產暴露出來。至於參數,我不小心把它弄亂了,而試圖讓綁定工作,但注意到好工作。感謝您關於輸出面板的評論,從現在開始,我將確保在調試時隨時打開它。 – hakas

相關問題