我有一个需要在顶部和下方UserControl
包含一堆控件的控件。LongListSelector
整体的总高度UserControl
可能(并且几乎总是会)超过屏幕高度,在这种情况下,整体UserControl
必须是可滚动的。
我目前的设置如下:
<staff:UserContentControl
xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:controls="clr-namespace:MyApp.Controls"
xmlns:staff="clr-namespace:MyApp.Helpers"
x:Class="MyApp.Controls.RemoteHomePage"
DataContext="{Binding RelativeSource={RelativeSource Self}}"
FontFamily="{StaticResource PhoneFontFamilyNormal}"
FontSize="{StaticResource PhoneFontSizeNormal}">
<ScrollViewer>
<ScrollViewer.Content>
<StackPanel>
<TextBlock Txt="Text1" Sign="@" />
<TextBlock Txt="Text2" Sign="#" />
<controls:Divider />
<TextBlock Txt="Text3" Sign="~" />
<TextBlock Txt="Text4" Sign="~" />
<controls:TextDivider Text="Divider text" />
<phone:LongListSelector ItemsSource="{Binding Items}">
<phone:LongListSelector.ItemTemplate>
<DataTemplate>
<TextBlock Text="{Binding Title}" />
</DataTemplate>
</phone:LongListSelector.ItemTemplate>
</phone:LongListSelector>
</StackPanel>
</ScrollViewer.Content>
</ScrollViewer>
</staff:UserContentControl>
这个解决方案满足了我的需求,但也有一个大问题:LongListSelector
当它包含的项目数量相当大时,目前确实需要很长时间才能加载。处理 300 个项目需要 8 秒,在此期间整个 UI 被阻塞。如果我删除所有内容,但是LongListSelector
,像这样:
<staff:UserContentControl
...>
<phone:LongListSelector ItemsSource="{Binding Items}">
<phone:LongListSelector.ItemTemplate>
<DataTemplate>
<TextBlock Text="{Binding Title}" />
</DataTemplate>
</phone:LongListSelector.ItemTemplate>
</phone:LongListSelector>
</staff:UserContentControl>
然后LongListSelector
几乎立即加载,即使有大量的项目。但显然我需要它上面的其他控件,所以问题是我能做些什么来解决这个问题?
(还有相关的问题:我担心LongListSelector
内部ScrollViewer
可能会导致双重滚动或类似的事情,但最终在这方面一切都很好。我不确定是否LongListSelector
以某种方式知道它在其他可滚动控件内,或者是否发生了其他事情我不知道。一些解释为什么它工作得很好,虽然很慢,但将不胜感激。)