我们可以在验证模板中有按钮,我们如何将它绑定到ViewModel方法?

时间:2010-12-29 15:31:45

标签: wpf binding command idataerrorinfo

要求:
当用户键入不存在的forlder名称时,需要显示错误消息,如下所示: alt text

问题:当用户点击“CreateNew”按钮时,我能够显示UI但无法在视图模型中调用方法

查看型号代码:

    public string this[string columnName]
    {
        get { return "The entered folder name doesn't exist."; }
    }

    RelayCommand createNewFolder;
    public RelayCommand CreateNewFolder
    {
        get
        {
            if (createNewFolder == null)
                createNewFolder = new RelayCommand(param => this.OnCreateNewFolder());
            return createNewFolder;

        }

    }
    public void OnCreateNewFolder()
    {
        MessageBox.Show("CreateNewFolder");
    }



可以在http://code.msdn.microsoft.com/Project/Download/FileDownload.aspx?ProjectName=mag200902MVVM&DownloadId=4357

下载RelayCommand.cs



Xaml代码:

<Window.Resources>        
    <ControlTemplate x:Key="validationTemplate">
        <DockPanel LastChildFill="True">
            <Border Margin="5,5,0,0" DockPanel.Dock="Bottom" Background="Red">
            <StackPanel>
                <TextBlock Name="ErrorText"  Foreground="White" Background="Red" 
                                   FontSize="12" Padding="2" FontFamily="Trebuchet MS"                                                                                
                                   TextWrapping="Wrap"                                        
                                   Text="{Binding [0].ErrorContent}" ></TextBlock>
                <StackPanel Margin="0" Orientation="Horizontal">
                    <Button Content="Create New" Command="{Binding Path=CreateNewFolder}" Margin="10" Padding="5"></Button>
                    <Button Content="Cancel" Margin="10" Padding="5" ></Button>
                </StackPanel>
            </StackPanel>
            </Border>
            <AdornedElementPlaceholder Name="ErrorTextBox" />
        </DockPanel>
    </ControlTemplate>
    <Style x:Key="ValidationStyle" TargetType="{x:Type ComboBox}">
        <Style.Triggers>
            <Trigger Property="Validation.HasError" Value="True">
                <Setter Property="BorderBrush" Value="Red" />
                <Setter Property="BitmapEffect">
                    <Setter.Value>
                        <BitmapEffectGroup>
                            <OuterGlowBitmapEffect GlowColor="Red" GlowSize="3" Noise="0.6"></OuterGlowBitmapEffect>
                        </BitmapEffectGroup>
                    </Setter.Value>
                </Setter> 
                <Setter Property="DataContext"
                        Value="{Binding RelativeSource={x:Static RelativeSource.Self},Path=DataContext}">
                </Setter>
            </Trigger>
        </Style.Triggers>
    </Style>
</Window.Resources>


<Grid>
    <AdornerDecorator >
        <ComboBox IsEditable="True" FontSize="11" Margin="10" Width="250"      
              VerticalAlignment="Center" 
              Text="{Binding Path=StrText, ValidatesOnDataErrors=True, UpdateSourceTrigger=PropertyChanged}" 
              Validation.ErrorTemplate="{StaticResource validationTemplate}"
              Style="{StaticResource ValidationStyle}"></ComboBox>
    </AdornerDecorator>
</Grid>


请注意,我在样式中设置了DataContext属性:

 <Setter Property="DataContext" Value="{Binding RelativeSource={x:Static 
          RelativeSource.Self},Path=DataContext}">
 </Setter>    



请告诉我如何将方法绑定到验证模板中的按钮。

2 个答案:

答案 0 :(得分:2)

您可以在Binding中引用AdornerDecorators Child的DataContext。我觉得这样的事情会起作用

<Button Content="Create New"
        Command="{Binding RelativeSource={RelativeSource AncestorType={x:Type AdornerDecorator}},
                          Path=Child.DataContext.CreateNewFolder}"
        Margin="10" Padding="5"></Button>

答案 1 :(得分:0)

这一行看起来很可疑:

createNewFolder = new RelayCommand(param => this.OnCreateNewFolder());

也许您应该通过以下方式替换它:

createNewFolder = new RelayCommand(OnCreateNewFolder);