WP8 LongListSelector - re-assigning ItemsSource ha

2019-04-05 23:16发布

I'm using the new Windows Phone 8 LongListSelector control, which has its ItemsControl assigned to a List<Group<object>> as so:

    List<Group<PlacePoint>> searchResults; 

    async void doSearch()
    {
        this.searchResults = await SearchHelper.Instance.getSearchResults(txtSearchTerm.Text);
        longList.ItemsSource = this.searchResults;
    }

Unfortunately, the second time that I search, re-setting the .ItemsSource property has no effect and the control simply displays the old List.

How can I change the binding?

3条回答
放荡不羁爱自由
2楼-- · 2019-04-06 00:07

Sometimes it helps to set the ItemsSource to null and then to your result right after.

查看更多
孤傲高冷的网名
3楼-- · 2019-04-06 00:11

It would seem that re-assigning longList.ItemsSource does not have any effect, whether this is a bug or by design I can't say.

However, an easy workaround is simply to use an ObservableCollection> instead and then work with this collection rather than re-assigning the ItemsSource.

Sample code:

    ObservableCollection<Group<PlacePoint>> searchResults = new ObservableCollection<Group<PlacePoint>>();


    public SearchPage()
    {
        InitializeComponent();

        longList.ItemsSource = this.searchResults;
    }

    async void doSearch()
    {
        List<Group<PlacePoint>> tempResults = await SearchHelper.Instance.getSearchResults(txtSearchTerm.Text);

        // Clear existing collection and re-add new results
        this.searchResults.Clear();
        foreach (Group<PlacePoint> grp in tempResults )
        {
            this.searchResults.Add(grp);
        }
    }
查看更多
倾城 Initia
4楼-- · 2019-04-06 00:11

You need to define your doSearch() method using async for await to function properly.

Try declaring you method like this:

private async Task doSearch() {

}
查看更多
登录 后发表回答