ListBox的ScrollIntoView方法

Silverlight中可以通过ScrollIntoView方法来定位具体的某一项。

前台界面定义一个ListBox,一个TextBox和一个Button,在TextBox中输入数字,点击Button定位到TextBox中指定的位置。

<StackPanel x:Name="LayoutRoot" Background="White" Height="400" Orientation="Vertical">
        <ListBox x:Name="lbRApproach" Grid.Row="1" Width="290" Height="200" Margin="0,33,0,0" Style="{StaticResource ListStyle}">
            <ListBox.ItemTemplate>
                <DataTemplate>
                    <Canvas Height="30">
                        <TextBlock Text="{Binding TicketName}" Foreground="#FF333333" FontSize="12" Canvas.Left="13" Canvas.Top="7" />
                        <TextBox x:Name="txtCash" Height="28" Width="180" TextWrapping="Wrap" BorderThickness="0" Style="{StaticResource jiesuanTextBoxStyle01}" Text="{Binding Amount}" Foreground="#FF4B4B4B" FontSize="16" FontWeight="Bold" Canvas.Left="63" Canvas.Top="1" />
                    </Canvas>
                </DataTemplate>
            </ListBox.ItemTemplate>
        </ListBox>
        <TextBox x:Name="txtView" Width="150" Height="50" />
        <Button x:Name="btnClick" Width="150" Height="50" Content="Click" />
    </StackPanel>
按钮事件
ContractedBlock.gif ExpandedBlockStart.gif 代码
 
   
void btnClick_Click( object sender, RoutedEventArgs e)
{
int currentRow = Convert.ToInt32(txtView.Text);
if (currentRow > lbRApproach.Items.Count)
{
MessageBox.Show(
" 超出范围,请重新输入 " );
return ;
}
lbRApproach.SelectedIndex
= Convert.ToInt32(txtView.Text) - 1 ;
lbRApproach.ScrollIntoView(lbRApproach.SelectedItem);
}

效果

2010080910274371.png

如果ListBox的数据源发生改变的时候,如添加或是删除一条数据,要先UpdateLayout,否则用ScrollIntoView不管用。

在界面上添加一个按钮,用来给ListBox添加一条数据,并定位到当条数据。

后台代码

 

ContractedBlock.gif ExpandedBlockStart.gif 代码
 
   
void btnAdd_Click( object sender, RoutedEventArgs e)
{
TicketTest t
= new TicketTest()
{
TicketName
= " Test " ,
Amount
= " 90 " ,
TicketType
= ""
};

ticket.Add(t);
this .lbRApproach.ItemsSource = null ;
this .lbRApproach.ItemsSource = ticket;
lbRApproach.SelectedIndex
= lbRApproach.Items.Count - 1 ;
// lbRApproach.UpdateLayout();
lbRApproach.ScrollIntoView(lbRApproach.SelectedItem);
}

没用用UpdateLayout方法,点击后数据添加了,虽然也用了ScrollIntoView方法,但是并没有想要的效果。

2010080910464557.png

采用LayoutUpdate方法后

2010080910480669.png

PS:代码没有加其他的一些验证

转载于:https://www.cnblogs.com/HellenTian/archive/2010/08/09/1795488.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值