• ASP.NET MVC 2自定义验证


    我将创建一个PriceAttribute来验证某个值是否大于指定的价格,并且这个价格必须以99分结束,因此$20.00是无效的值,$19.99是有效的。下面是这个属性的代码:

    以下是代码片段:
    public class PriceAttribute : ValidationAttribute {
    public double MinPrice { get; set; }

    public override bool IsValid(object value) {
    if (value == null) {
    return true;
    }
    var price = (double)value;
    if (price < MinPrice) {
    return false;
    }
    double cents = price - Math.Truncate(price);
    if(cents < 0.99 || cents >= 0.995) {
    return false;
    }

    return true;
    }
    }  

    注意如果值为空,返回的值是true,这个属性不会验证字段是否需要。我会在RequiredAttribute中验证值是否需要。它允许我将属性放在可选的值上,当用户将这个字段留为空时显示一个错误。

    我们可以创建一个视图模型,然后应用这个属性到模型上进行快速测试,下面是这个模型的代码:

    以下是代码片段:
    public class ProductViewModel { 
    [Price(MinPrice = 1.99)]
    public double Price { get; set; }

    [Required]  www.szfuao.com
    public string Title { get; set; }
    }

    我们再快速地创建一个视图(Index.aspx)显示和编辑窗体:<%@ Page Language="C#" Inherits="ViewPage" %>

    以下是代码片段:
    <%@ Page Language="C#" Inherits="ViewPage" %>

    <% using (Html.BeginForm()) { %>

    <%= Html.TextBoxFor(m => m.Title) %>
    <%= Html.ValidationMessageFor(m => m.Title) %>
    <%= Html.TextBoxFor(m => m.Price) %>
    <%= Html.ValidationMessageFor(m => m.Price) %>

    <input type="submit" />
    <% } %> <% using (Html.BeginForm()) { %><%= Html.TextBoxFor(m => m.Title) %><%= Html.ValidationMessageFor(m => m.Title) %><%= Html.TextBoxFor(m => m.Price) %><%= Html.ValidationMessageFor(m => m.Price) %><% } %>

     

    现在我们只需要一个有两个行为的控制器,一个编辑视图,另一个接收提交的ProductViewModel。

    以下是代码片段:
    [HandleError]  www.yzjxsp.com
    public class HomeController : Controller {
    public ActionResult Index() {
    return View(new ProductViewModel());
    }

    [HttpPost]
    public ActionResult Index(ProductViewModel model) {
    return View(model);
    }
    }

  • 相关阅读:
    【linux】linux根文件系统制作
    【linux】UBUNTU 12.04下傻瓜式简单安装arm-linux-gcc等gnu arm toolchain交叉编译工具
    【linux】内核编译
    【linux】内核源代码下载与阅读
    Jmeter实践
    常用sql 2018.08.31
    接口用例、实践参考
    UTF自动化测试工具
    MySql 中IFNULL、ISNULL、NULLIF用法(数据库判空)
    Mysql中FIND_IN_SET()和IN区别简析
  • 原文地址:https://www.cnblogs.com/haosola/p/1956568.html
Copyright © 2020-2023  润新知