微软企业库验证 Validations

using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Microsoft.Practices.EnterpriseLibrary.Validation;
using ValidationResult = System.ComponentModel.DataAnnotations.ValidationResult;

namespace Blackice.Suite.Domains.Validations
{
    /// <summary>
    /// 企业库验证操作
    /// </summary>
    public class Validation : IValidation
    {
        /// <summary>
        /// 验证
        /// </summary>
        /// <param name="target">验证目标</param>
        public ValidationResultCollection Validate(object target)
        {
            var validator = ValidationFactory.CreateValidator(target.GetType());
            var results = validator.Validate(target);
            return GetResult(results);
        }

        /// <summary>
        /// 获取验证结果
        /// </summary>
        private ValidationResultCollection GetResult(IEnumerable<Microsoft.Practices.EnterpriseLibrary.Validation.ValidationResult> results)
        {
            var result = new ValidationResultCollection();
            foreach (var each in results)
                result.Add(new ValidationResult(each.Message));
            return result;
        }
    }

    /// <summary>
    /// 验证操作
    /// </summary>
    public interface IValidation
    {
        /// <summary>
        /// 验证
        /// </summary>
        /// <param name="target">验证目标</param>
        ValidationResultCollection Validate(object target);
    }
    /// <summary>
    /// 验证结果集合
    /// </summary>
    public class ValidationResultCollection : IEnumerable<ValidationResult>
    {
        /// <summary>
        /// 初始化验证结果集合
        /// </summary>
        public ValidationResultCollection()
        {
            _results = new List<ValidationResult>();
        }
        /// <summary>
        /// 验证结果
        /// </summary>
        private readonly List<ValidationResult> _results;

        /// <summary>
        /// 是否有效
        /// </summary>
        public bool IsValid
        {
            get
            {
                return _results.Count == 0;
            }
        }

        /// <summary>
        /// 验证结果个数
        /// </summary>
        public int Count
        {
            get
            {
                return _results.Count;
            }
        }

        /// <summary>
        /// 添加验证结果
        /// </summary>
        /// <param name="result">验证结果</param>
        public void Add(ValidationResult result)
        {
            if (result == null)
                return;
            _results.Add(result);
        }

        /// <summary>
        /// 添加验证结果集合
        /// </summary>
        /// <param name="results">验证结果集合</param>
        public void AddResults(IEnumerable<ValidationResult> results)
        {
            if (results == null)
                return;
            foreach (var result in results)
                Add(result);
        }

        /// <summary>
        /// 获取迭代器
        /// </summary>
        IEnumerator<ValidationResult> IEnumerable<ValidationResult>.GetEnumerator()
        {
            return _results.GetEnumerator();
        }

        /// <summary>
        /// 获取迭代器
        /// </summary>
        IEnumerator IEnumerable.GetEnumerator()
        {
            return _results.GetEnumerator();
        }

        public IEnumerator GetEnumerator()
        {
            return _results.GetEnumerator();
        }
    }
}

 

转载于:https://www.cnblogs.com/blackice/p/5419336.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果 `validations` 属性不起作用,可能是以下几个原因导致的: 1. 忘记在组件选项中导入 `VeeValidate`。确保在组件的选项中导入了 `VeeValidate`: ```js import { ValidationObserver, ValidationProvider } from 'vee-validate' export default { components: { ValidationObserver, ValidationProvider }, // ... } ``` 2. 没有在 `data` 中声明需要验证的表单数据。`validations` 属性中的验证规则需要和表单数据进行绑定才能生效。例如: ```js data() { return { email: '', password: '', validations: { email: { required, email }, password: { required, min: minlength(6) } } } }, ``` 在这个例子中,我们在 `data` 中声明了需要验证的表单数据 `email` 和 `password`,并且将验证规则绑定到了这些表单数据上。 3. 没有在表单元素上使用 `v-model` 和 `v-validate` 指令。表单元素需要使用 `v-model` 来绑定表单数据,使用 `v-validate` 来指定验证规则。例如: ```html <template> <form> <div> <label for="email">Email</label> <input id="email" type="email" name="email" v-model="email" v-validate="'required|email'"> <span v-show="errors.has('email')">{{ errors.first('email') }}</span> </div> <div> <label for="password">Password</label> <input id="password" type="password" name="password" v-model="password" v-validate="'required|min:6'"> <span v-show="errors.has('password')">{{ errors.first('password') }}</span> </div> <button type="submit">提交</button> </form> </template> ``` 在这个例子中,我们在表单元素上使用了 `v-model` 来绑定表单数据 `email` 和 `password`,使用 `v-validate` 来指定了验证规则。 如果以上几个步骤都已经正确执行,但是 `validations` 属性仍然不起作用,可能是其他问题导致的,比如版本不兼容等。你可以查看 VeeValidate 的文档,或者在 GitHub 上提交一个 issue 寻求帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值