我从我的sqlite数据库
填充我的listviewprivate async void getBowlers()
{
SQLiteAsyncConnection conn = new SQLiteAsyncConnection(BOWLERS_DATABASE);
var query = conn.Table<Bowler>();
var result = await query.ToListAsync();
List<String> names = new List<String>();
foreach (var item in result)
{
names.Add(item.Name);
}
itemListView.ItemsSource = names;
}
当我点击列表中的某个项目时,如何获取与所点击的项目相关联的数据?
因为我只是用字符串列表填充列表,所以我真的不知道如何将任何数据与它相关联,那么是否有另一种方法来填充我的listview?即使只是获得ID
也没关系,我可以根据ID
答案 0 :(得分:0)
您可以将ListView
绑定到对象,而不仅仅是字符串。如果这样做,当单击某个项目时,您将返回该对象。在您的情况下,您可以绑定到Bowler
对象,我假设该对象具有ID
和Name
字段:
public class Bowler
{
public int Id { get; set; }
public string Name { get; set; }
}
在您的XAML中,您必须告诉ListView
您要绑定Name
字段。这是一个简单的ListView
,每个项目只有TextBlock
:
<ListView x:Name="itemListView" ItemsSource="{Binding}"
IsItemClickEnabled="True" ItemClick="itemListView_ItemClick">
<ListView.ItemTemplate>
<DataTemplate>
<TextBlock Text="{Binding Name}"></TextBlock>
</DataTemplate>
</ListView.ItemTemplate>
</ListView>
在上文中,TextBlock
将显示Name
字段。
要将项目加载到列表中,您可以将上述方法更改为:
// Unrelated, but generally you want to use "async Task"
// in the method signature. "async void" should only be used by
// event handlers, such as a click event.
private async Task getBowlers()
{
SQLiteAsyncConnection conn = new SQLiteAsyncConnection(BOWLERS_DATABASE);
var query = conn.Table<Bowler>();
var result = await query.ToListAsync();
// set page's data context to bowler collection
this.DataContext = result;
}
现在,当单击某个项目时,您将返回相关的Bowler
对象:
private void itemListView_ItemClick(object sender, ItemClickEventArgs e)
{
Bowler bowler = (Bowler)e.ClickedItem;
// do something with bowler...
}