Ton*_*ith 8 silverlight xaml binding date textblock
我来自Flex,您可以在花括号内做任何事情.我试图在TextBlock没有用C#编码的情况下显示今天的日期和时间.我尝试了以下许多不同的变化而没有运气.
TextBlock Text="{Source=Date, Path=Now, StringFormat='dd/MM/yyyy'}"
Run Code Online (Sandbox Code Playgroud)
我知道我可能只是设置一个属性MyDate并绑定到那个,但为什么我不能直接绑定到DateTime.Now属性?
Ant*_*nes 14
Silverlight中的绑定需要Source对象或Dependency对象.从该源对象,您可以绑定到Properties(因此根据定义,您绑定到实例成员)或依赖属性.
由于DateTime.Now是静态属性,因此无法直接在Silverlight中绑定它,因此需要一些代码.下一个最好的事情是使用代码: -
因此,我们可以分析我们需要两件事.
为了处理第一项,我将创建一个StaticSurrogate类,在那里我将为我们需要访问的静态属性创建实例属性: -
public class StaticSurrogate
{
public DateTime Today { get { return DateTime.Today; } }
public DateTime Now { get { return DateTime.Now; } }
}
Run Code Online (Sandbox Code Playgroud)
现在我们需要一种格式化日期时间的方法.价值转换器是这项工作的正确工具,大量借鉴Tim Heuer博客: -
public class FormatConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
if (parameter != null)
{
string formatterString = parameter.ToString();
if (!String.IsNullOrEmpty(formatterString))
{
return String.Format(culture, String.Format("{{0:{0}}}", formatterString), value);
}
}
return (value ?? "").ToString();
}
public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
throw new NotImplementedException();
}
}
Run Code Online (Sandbox Code Playgroud)
有了这两个类,我们现在可以在Xaml中完成其余的工作,首先我们需要在我们的资源中使用这些类的实例:
<UserControl.Resources>
<local:StaticSurrogate x:Key="Static" />
<local:FormatConverter x:Key="Formatter" />
</UserControl.Resources>
Run Code Online (Sandbox Code Playgroud)
现在我们可以连线TextBlock: -
<TextBlock Text="{Binding Today, Source={StaticResource Static},
Converter={StaticResource Formatter}, ConverterParameter='dd MMM yyy'}" />
Run Code Online (Sandbox Code Playgroud)
请注意,此方法具有以下优点: -
StaticSurrogate类中.即使你可以在Silverlight的XAML中声明DateTime.Now(因为你可以在WPF中 - http://soumya.wordpress.com/2010/02/12/wpf-simplified-part-11-xaml-tricks/),你有你的时间不会更新的问题.如果您使用本地计时器在第二个更新,您可以确保您的时间也将更新.
public class LocalTimer : INotifyPropertyChanged
{
private DispatcherTimer timer;
public LocalTimer()
{
timer = new DispatcherTimer();
timer.Interval = TimeSpan.FromSeconds(1.0);
timer.Tick += new EventHandler(TimerCallback);
this.TimeFormat = "hh:mm:ss";
this.DateFormat = "dddd, MMMM dd";
}
private void TimerCallback(object sender, EventArgs e)
{
PropertyChanged(this, new PropertyChangedEventArgs("FormattedDate"));
PropertyChanged(this, new PropertyChangedEventArgs("FormattedTime"));
}
public bool Enabled
{
get { return this.timer.IsEnabled; }
set { if (value) this.timer.Start(); else this.timer.Stop(); }
}
public string FormattedDate { get { return DateTime.Now.ToString(this.DateFormat); } set {} }
public string FormattedTime { get { return DateTime.Now.ToString(this.TimeFormat); } set{} }
public string TimeFormat { get; set; }
public string DateFormat { get; set; }
#region INotifyPropertyChanged Members
public event PropertyChangedEventHandler PropertyChanged;
#endregion
}
Run Code Online (Sandbox Code Playgroud)
在xaml ala中声明一个这样的实例:
<local:LocalTimer x:Key="theTime" Enabled="True" />
Run Code Online (Sandbox Code Playgroud)
并使用绑定来确保始终反映您的时间.
<TextBlock Text="{Binding Source={StaticResource theTime}, Path=FormattedDate, Mode=OneWay}" x:Name="TodaysDate" />
<TextBlock Text="{Binding Source={StaticResource theTime}, Path=FormattedTime, Mode=OneWay}" x:Name="CurrentTime" />
Run Code Online (Sandbox Code Playgroud)