Silverlight DataGrid列验证

时间:2012-06-06 09:53:54

标签: c# silverlight binding mvvm datagrid

我的应用程序中有一个datagrid,我需要某些datagrid列,其值的总和等于100.

如:

20

b 20

c 60

这个是对的

20

b 20

c 62

这个是不对的

有什么想法我可以用MVVM ad INotifyDataErrorInfo实现这个吗?

我现在的问题是,如果我只是将属性绑定到单元格然后抛出ErrorChanged,datagrid将锁定我已更改数据的行,所以除非我恢复原始值,否则我将无法移动到任何地方该列中的总和将再次变为100。

不要在CellEdit或类似的东西上发布带有手动验证的各种代码隐藏解决方案 - 我可以自己编写这样的脏代码。我正在尝试找到适合绑定和MVVM的干净解决方案

据我所知,虽然 Silverlight数据网格完全破碎,未完成且无人问津。也许有人知道那里有正确的数据网格。(或者他们实际上可以在Silverlight 5中修复它?)

目前正在使用:

在我的ViewModel构造函数

        validator = new Validator(this);
        validator.AddValidationFor(() => PayElements).When(() => _payElements.Where(p1 => (!String.IsNullOrEmpty(p1.Distribution) && FormatChecker.IsDecimal(p1.Distribution, 3, 2))).Sum(p2 => Decimal.Parse(p2.Distribution)) != 100).Show("ERROR!");

其中PayElements是我的收藏(顺便说一下,我的错,它实际上是从_payElements创建的ICollectionView,它是ObservableCollection)。然后OnChanges到任何对象

        validator.ValidateAll();

导致在构造函数中创建的验证规则被评估。在此之后,我在整个对象集合的viewmodel的errorCOllection中有错误,但它没有显示任何红色边框。列表中我可以看到有错误并禁用保存按钮:)

1 个答案:

答案 0 :(得分:0)

我在datagrid上实现了讨厌的验证,除非你必须执行异步验证,否则从绑定对象中做得非常好。我不确定你绑定到列表的对象,但我会使用类似下面的内容:

public string Col1Wrapper
{
    get
    {
        return this.Col1;
    }
    set
    {
        ValidateRequired("Col1Wrapper", value, "Required");
        ValidateRegularExpression("Col1Wrapper", value, @"^[\d]+$", "Must be digit");
        ValidateTotal(value,Col2,Col3,total);//in your case
        this.Col1 = value;
        this.RaisePropertyChanged("Col1Wrapper");
    }
}

public string Col2Wrapper
{
    get
    {
        return this.Col2;
    }
    set
    {
        ValidateRequired("Col2Wrapper", value, "Required");
        ValidateRegularExpression("Col2Wrapper", value, @"^[\d]+$", "Must be digit");
        ValidateTotal(Col1,value,Col3,total);//in your case
        this.Col2 = value;
        this.RaisePropertyChanged("Col2Wrapper");
    }
}

public string Col3Wrapper
{
    get
    {
        return this.Col3;
    }
    set
    {
        ValidateRequired("Col3Wrapper", value, "Required");
        ValidateRegularExpression("Col3Wrapper", value, @"^[\d]+$", "Must be digit");
        ValidateTotal(Col1,Col2,value,total);//in your case
        this.Col3 = value;
        this.RaisePropertyChanged("Col3Wrapper");
    }
}

然后使用http://msdn.microsoft.com/en-us/library/system.componentmodel.inotifydataerrorinfo%28VS.95%29.aspx

默认实现在示例部分。

public bool ValidateRequired(string property, string value, string errorMessage)
{
    bool isValid = true;

    if (value == null || value == string.Empty)
    {
        AddError(property, errorMessage, false);
        isValid = false;
    }
    else RemoveError(property, errorMessage);
    RaiseErrorsChanged(property);
    return isValid;
}

public bool ValidateRegularExpression(string property, string value, string expression, string errorMessage)
{
    ...
}

public bool ValidateTotal(string property,int 1, int 2, int 3, int total, string errorMessage)
{
    if((1+2+3) != total)
        AddError(property, errorMessage, false);
    else RemoveError(property, errorMessage);
}

添加错误方法将触发验证摘要显示在数据网格上。希望这是你想要的。