Xamarin.Forms listview中的button按钮,实现带着参数返回上一级页面
今天在做列表显示的时候遇到一个问题,就是在ListView中如何才能让一个button的按钮工作并且包含参数呢?
其实有点类似于rep里的控件无法起获取一样。在Xamarin中,当你button绑定事件并不包含在listview的数据源中,那么这个按钮的事件便是无效的。
那么该怎么解决呢?找了一下午终于找到了解决方案
xaml:
<AbsoluteLayout IsVisible="True" HorizontalOptions="EndAndExpand"> <renderers:CiCoButton x:Name="ButtonName" BorderRadius="2" BackgroundColor="{StaticResource color}" HeightRequest="36" WidthRequest="36" AbsoluteLayout.LayoutFlags="PositionProportional" AbsoluteLayout.LayoutBounds=".5,.5,-1,-1" TextColor="White" Command="{Binding Path=BindingContext.functionName, Source={x:Reference Name=ListviewName}}" CommandParameter="{Binding Id}" /> <Image Source="ic_add_white" AbsoluteLayout.LayoutFlags="PositionProportional" AbsoluteLayout.LayoutBounds=".5,.5,-1,-1"/> </AbsoluteLayout>
问题的关键在于,Button怎么存数据和如何找到ViewModel中的Command方法
在网上找到这么一种绑定的写法“
{Binding Path=BindingContext.functionName, Source={x:Reference Name=ListviewName}}
”
Path 指的是你的方法名,BindingContext相当于你的上下文,然后用它点出来你的ViewModel中的方法名,后面则是要把数据绑定到哪里,那么,Name,理所应当就是你所在listview中的名字了
ViewModel:
private ICommand _backCommand; public ICommand BackCommand { get { return _backCommand ?? (_backCommand = new Command<string>(async (id) => {await BackPage(id);})); } } private async Task BackPage(string id) { var page = Navigation.NavigationStack.FirstOrDefault(p => p is OutPage); var vm = page.BindingContext as OutViewModel; if (vm != null) { // 你想要做的事情 } else { "Can't find ".ToToast(); } await Navigation.PopAsync(true); }
那么,Viewmodel中的command方法就要这样写了,new Command<string>(async (id) => {await BackExamStaffPage(id);} 这里对应着page中Button的CommandParamete
Navigation.NavigationStack.FirstOrDefault(p => p is OutPage);从所有打开的页面中,找到你想要返回的上一个页面(当然如果你不需要参数的话直接Pop就好了)
page.BindingContext as OutViewModel; 利用BindingContext转换为你需要的ViewModel,那么,再接下来,你想干嘛都可以楼