我正在为我们的
一个部门提供数据验证实用程序,该实用程序具有以下要求.
– 动态
添加新的业务实体
– 动态地向实体
添加新验证.
– 用于
显示业务实体及其有效性列表的UI
–
用户可以选择在所有或选择的业务实体验证上启动验证.
– 如果任何验证失败,UI将
显示验证
错误消息.
– 即使任何验证失败,系统也应继续进行下一次验证,从而验证所有已配置的验证.
在搜索互联网后,我发现以下2个承诺设计模式满足我的业务需求一个id装饰模式,另一个是命令链(又称责任链).现在我的问题是哪个更好?有人有更好的主意吗?
谢谢
我想你想要的是
Specification Pattern.所以你会这样做:
public void StartDatenotinPastSpecification : ISpecification<ISomeBusinessObject>
{
public bool IsSatisfiedBy(ISomeBusinessObject myBusinessObject)
{
return myBusinessObject.StartDate >= DateTime.Now;
}
}
关于这种模式的好处是每个规则都可以单独测试,你可以选择何时应用验证规则(而不是某些框架将这个决定强加给你).