Silverlight初体验之-Slider控件ValueChanged事件

在我练习Slider控件的时候,有遇到一些问题和大家分享下

当拖动Slider控件的小滑块时,Slider的值将会改变。当Slider的值改变的时候,会触发ValueChanged事件,在这个事件中获取Slider控件当前的值,并显示出来。本来这是一个很简单的问题,但是,当我设置Slider控件有默认值(value属性)的时候就会有异常(页面打开一直显示加载100%),如果去掉Value属性的话就不会出现这样的错误。

前端代码如下:

ContractedBlock.gif ExpandedBlockStart.gif 代码
 
   
1 < StackPanel x:Name = " LayoutRoot " Background = " White " >
2 < Slider x:Name = " TestSlider " Margin = " 10 "
3 Minimum = " 0 " Maximum = " 100 "
4 Value = " 20 "
5 ValueChanged = " TestSlider_ValueChanged " >
6 </ Slider >
7 < TextBlock x:Name = " ShowValue " Margin = " 10 " Text = " Slider当前的值: " >
8 </ TextBlock >
9 </ StackPanel >

后台代码如下:

ContractedBlock.gif ExpandedBlockStart.gif 代码
 
   
1 using System;
2   using System.Collections.Generic;
3 using System.Linq;
4 using System.Net;
5 using System.Windows;
6 using System.Windows.Controls;
7 using System.Windows.Documents;
8 using System.Windows.Input;
9 using System.Windows.Media;
10 using System.Windows.Media.Animation;
11 using System.Windows.Shapes;
12
13 namespace SilverlightApplication2
14 {
15 public partial class Test3 : UserControl
16 {
17 public Test3()
18 {
19 InitializeComponent();
20 }
21
22 private void TestSlider_ValueChanged( object sender, RoutedPropertyChangedEventArgs < double > e)
23 {
24 this .ShowValue.Text = " Slider当前的值: " + this .TestSlider.Value;
25 }
26
27 }
28 }

遇到这个错误后,我在网上查找了一些资料,终于找到了原因:如果XAML中设置了Slider控件的Value属性,就不能再在XAML中注册ValueChanged事件,否则将会引发异常。如果需要在设定Value属性的情况下在注册ValueChanged事件,可以通过托管代码在页面构造函数中注册。这样的话我们只需要稍微修改上面的代码就可以解决掉这个问题了,在前台代码中,去掉Slider控件的ValueChanged事件,然后在后台代码的构造函数中加上一句话this.TestSlider.ValueChanged+=new RoutedPropertyChangedEventHandler<double>(TestSlider_ValueChanged);这句话的意思是重新注册ValueChanged事件。注:这句话一定要写在InitializeComponent();方法下面,不然会有异常。添加后保存,这样就OK了。

转载于:https://www.cnblogs.com/Rosy/archive/2010/05/05/1728132.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值