0

所以我有一个简单的自定义验证属性:

public class MyCustomValidator : CustomValidationAttribute
{
    public bool IsLive { get; set; }

    public MyCustomValidator()
    {
        //Service locator stuff
    }

    protected override ValidationResult IsValid(object value, ValidationContext validationContext)
    {
        return ValidationResult.Success;
    }
}

MyCustomValidor 继承了下面的类,因为我所有的自定义验证器都需要访问它。

public abstract class CustomValidationAttribute : ValidationAttribute
{
    public Type MessageResource { get; set; }

    public string MessagePrefix { get; set; }
}

然后我在我的 viewModel 中调用它,它看起来有点像这样:

public class MyViewModel
{
    private static bool IsWebLive;

    [MyCustomValidator(IsWebLive = IsWebLive, MessageResource = typeof(MyResourceFile), MessagePrefix = "ErrorMessage")]
    public string SampleValue { get; set; }
}

在我将私人传递给IsWebLive我的地方,validator我收到一个错误,说an attribute argument must be a constant expression, typeof expression or array. 我知道我可能做错了。但是我怎么能把这个布尔值传递给验证器,因为我无法访问系统中其他任何地方的设置;

我也不能私下设置IsLive/MessageResource/MessagePrefixMyCustomValidator因为我的自定义验证器的东西是通用的,MessagePrefix并且MessageResource可以在我的所有自定义验证器中访问。

4

2 回答 2

1

抱歉,这是不可能的。属性的构造函数参数必须在编译时知道,因为它们旨在作为类型或方法的元数据,而不是每次调用或实例使用的东西。

于 2014-08-04T11:27:24.347 回答
0

您可以做的是简单地使用 CustomValidationAttribute 为其提供静态方法来进行验证。调用静态方法时,您提供的参数之一是验证上下文,它将包含视图模型中 ObjectInstance 属性下的所有属性。因此,例如,您可以简单地让 IsWebLive 可供您在静态方法中进行条件测试。不需要继承也不需要 IsLive 属性。

于 2014-10-22T14:55:43.520 回答