Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/xamarin/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Xaml Xamarin-CollectionView,将当前项作为命令参数传递_Xaml_Xamarin - Fatal编程技术网

Xaml Xamarin-CollectionView,将当前项作为命令参数传递

Xaml Xamarin-CollectionView,将当前项作为命令参数传递,xaml,xamarin,Xaml,Xamarin,我有一个CollectionView,它绑定到一个ObservableCollection,在视图的每一行中我有一个(LIKE/inspect)按钮,当单击该按钮时,调用ViewModel上的一个命令,该命令应该读取ID+状态(选中/取消选中按钮),以确定它是否应该执行LIKE或dispect API调用。 我的问题是,如何将当前项(按钮的父行)作为命令参数(产品类型)传递 这是我的XAML: <CollectionView ItemsSource="{Binding Produ

我有一个CollectionView,它绑定到一个ObservableCollection,在视图的每一行中我有一个(LIKE/inspect)按钮,当单击该按钮时,调用ViewModel上的一个命令,该命令应该读取ID+状态(选中/取消选中按钮),以确定它是否应该执行LIKE或dispect API调用。 我的问题是,如何将当前项(按钮的父行)作为命令参数(产品类型)传递

这是我的XAML:

<CollectionView ItemsSource="{Binding Products}" SelectionMode="Single" SelectedItem="{Binding SelectedProduct , Mode=TwoWay}" RemainingItemsThreshold="{Binding ItemsThreshold}" RemainingItemsThresholdReachedCommand="{Binding LoadProductsCommand}" BackgroundColor="Fuchsia">
                <CollectionView.ItemsLayout>
                    <GridItemsLayout Orientation="Vertical" VerticalItemSpacing="10"></GridItemsLayout>
                </CollectionView.ItemsLayout>
                <CollectionView.ItemTemplate>
                    <DataTemplate>
                        <Frame BorderColor="Black" BackgroundColor="Green" HeightRequest="100" Padding="0" Margin="0 , 10" HasShadow="True">
                            <Grid Padding="0">
                                <Grid.RowDefinitions>
                                    <RowDefinition Height="*"></RowDefinition>
                                    <RowDefinition Height="*"></RowDefinition>
                                </Grid.RowDefinitions>
                                <Grid.ColumnDefinitions>
                                    <ColumnDefinition Width="*"></ColumnDefinition>
                                    <ColumnDefinition Width="*"></ColumnDefinition>
                                </Grid.ColumnDefinitions>

                                <Image Source="{Binding photo_1}" Aspect="AspectFill" Grid.Row="0" Grid.Column="0"></Image>

                                <StackLayout Grid.Row="1" Grid.Column="1" BackgroundColor="Yellow" HorizontalOptions="End">
                                    <button:SfButton Text="HEART" IsCheckable="True" IsChecked="{Binding liked}" Command="{Binding Source={x:Reference MyProductsPage} , Path=BindingContext.LikeCommand}" CommandParameter="{Binding ???}"></button:SfButton>
                                    <Label Text="{Binding total_likes}" HorizontalTextAlignment="Center"></Label>
                                </StackLayout>

                            </Grid>
                        </Frame>
                    </DataTemplate>
                </CollectionView.ItemTemplate>
            </CollectionView>

就像这样绑定:

<button:SfButton Text="HEART" IsCheckable="True" IsChecked="{Binding liked}" Command="{Binding Source={x:Reference MyProductsPage} , Path=BindingContext.LikeCommand}" CommandParameter="{Binding .}"></button:SfButton>


下面是代码示例:

工作得很好!谢谢!