4

我正在使用日历DisplayMode="Year"this.DataContext = new SampleModel();因此我可以访问模型的属性。然而日历呈现错误(见截图)

代码归结为:Xaml:

<Window x:Class="Excel2.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindow" Height="600" Width="800">
    <Grid>
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="250"></ColumnDefinition>
            <ColumnDefinition Width="2*"></ColumnDefinition>
        </Grid.ColumnDefinitions>
        <Grid.RowDefinitions>
            <RowDefinition Height="220"></RowDefinition>
            <RowDefinition Height="*"></RowDefinition>
        </Grid.RowDefinitions>

        <Calendar DisplayMode="Year"></Calendar>
    </Grid>
</Window>

后面的代码:

using ....

namespace Excel2
{
    class SampleModel
    {
    }

    public partial class MainWindow : Window
    {
        public MainWindow()
        {            
            InitializeComponent();
            this.DataContext = new SampleModel();
        }
    }
}

结果: XAML 日历显示模式=年份错误 如您所见,日历渲染时没有显示任何年份信息。

如果我不使用网格定义,Displaymode=Year或者this.DataContext =...一切都正确呈现。

这是 XAML 中的错误吗?

4

1 回答 1

4

由于这个问题已经被问了一年多,但仍然没有任何可接受的答案,所以我想为我如何摆脱这个错误做出贡献。

我将我的 xaml 更改为:

 <Calendar Grid.Row="0" Grid.Column="3" x:Name="_calendar" DisplayModeChanged="_calendar_DisplayModeChanged" Loaded="_calendar_OnLoaded"
                          DisplayDate="{Binding SelectedMonth, UpdateSourceTrigger=PropertyChanged}" DisplayMode="Month" />

 //Setting DisplayMode="Month" in xaml and will change it back to "Year" in code behind. so my codebehind code is


    private void _calendar_DisplayModeChanged(object sender, CalendarModeChangedEventArgs e)
    {
        _calendar.DisplayMode = CalendarMode.Year;
    }

    private void _calendar_OnLoaded(object sender, RoutedEventArgs e)
    {
        _calendar.DisplayMode = CalendarMode.Year;
    }

需要加载事件才能首次更改显示模式,并且在选择更改时,需要在随后的呼叫上更改DisplayModechanged事件。

我希望它对将来的人有所帮助。

于 2015-10-31T03:00:42.020 回答