• 一起谈.NET技术,ASP.NET MVC 入门介绍 (下) 狼人:


      相关文章:ASP.NET MVC 入门介绍 (上)

      接上文,我们来完善验证功能。在System.ComponentModel.DataAnnotations命名空间中,已经有了一些基本的属性类来实现验证功能,只要把这些属性加到Model的字段上就可以了。具体的属性类可以查MSDN, 下面给出一个例子:

    public class Movie
    {
    [Key,DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public int ID { get; set; }
    [StringLength(
    10,MinimumLength=2,ErrorMessage="必须是2~10个字符长"),Required,Display(Name="名称")]
    public string Title { get; set; }
    [Display(Name
    ="发布日期")]
    public DateTime ReleaseDate { get; set; }
    public string Genre { get; set; }
    [Range(
    1,100,ErrorMessage="必须是1~100")]
    public decimal Price { get; set; }
    public string Rating { get; set; }
    }

      再运行下程序,就可以看到效果:

    image

      当然,默认的验证往往并不足够,可以尝试下将日期改为201-01-1,点击Create,就会引发异常。我们可以增加自定义的验证属性来满足验证要求。下面我们来实现一个DateAttribute属性来实现日期格式和日期范围的检查。新建一个动态链接库Biz.Web,添加System.ComponentModel.DataAnnotations引用,新建一个类如下:

    using System;
    using System.Collections.Generic;
    using System.ComponentModel.DataAnnotations;
    using System.Data.SqlClient;

    namespace Biz.Web
    {
    [AttributeUsage(AttributeTargets.Property
    | AttributeTargets.Field, AllowMultiple = false)]
    public class DateAttribute:ValidationAttribute
    {
    public DateAttribute()
    {
    //set default max and min time according to sqlserver datetime type
    MinDate = new DateTime(1753, 1, 1).ToString();
    MaxDate
    = new DateTime(9999, 12, 31).ToString();
    }

    public string MinDate
    {
    get;
    set;
    }

    public string MaxDate
    {
    get;
    set;
    }

    private DateTime minDate, maxDate;
    //indicate if the format of the input is really a datetime
    private bool isFormatError=true;

    public override bool IsValid(object value)
    {
    //ignore it if no value
    if (value == null || string.IsNullOrEmpty(value.ToString()))
    return true;
    //begin check
    string s = value.ToString();
    minDate
    = DateTime.Parse(MinDate);
    maxDate
    = DateTime.Parse(MaxDate);
    bool result = true;
    try
    {
    DateTime date
    = DateTime.Parse(s);
    isFormatError
    = false;
    if (date > maxDate || date < minDate)
    result
    = false;
    }
    catch (Exception)
    {
    result
    = false;
    }
    return result;
    }

    public override string FormatErrorMessage(string name)
    {
    if (isFormatError)
    return "请输入合法的日期";
    return base.FormatErrorMessage(name);
    }
    }
    }

      主要实现IsValid方法,如有需要也可以实现FormatErrorMessage方法。要注意属性的参数只能是有限的几种类型,参考这里。写好以后,把HelloWorld项目添加Biz.Web引用,然后就可以使用了,例如:

    [Display(Name="发布日期"),Date(MaxDate="2012-01-01",ErrorMessage="2012地球灭亡啦")]
    public DateTime ReleaseDate { get; set; }

      看下效果:

    image  当然,这种方式有许多限制,主要是属性参数的限制,只能是基本类型,而且只能是常量。更复杂的验证规则的添加请看这里:

      Implement Remote Validation in ASP.NET MVC.

      下面为lndex页面加上一些筛选功能。通过给Index传递参数来实现筛选,在页面添加一个selectbox来筛选Genre字段,把MovieController的方法改成:

    public ViewResult Index(string movieGenre)
    {
    var genre
    = (from s in db.Movies
    orderby s.Genre
    select s.Genre).Distinct();
    ViewBag.MovieGenre
    = new SelectList(genre); //给前台准备下拉列表的数据。
    if (!string.IsNullOrEmpty(movieGenre))
    {
    //筛选
    var movies = from s in db.Movies where s.Genre == movieGenre select s;
    return View(movies);
    }
    return View(db.Movies.ToList());
    }

      在View页面,添加一个Form,里面放上一个选择框和一个按钮,代码如下:

    @using (Html.BeginForm("Index", "Movie", FormMethod.Get))
    {
    <p>Genre: @Html.DropDownList("MovieGenre","全部") <input type="submit" value="筛选" /></p>
    }

      效果如下:

    image

  • 相关阅读:
    python自定义ORM并操作数据库
    python 元类理解
    Python中type()详解:动态创建类
    Centos7安装教程
    数据库建模:学生信息系统搭建实验
    数据库索引、视图与触发器
    用python批量插入数据到数据库中
    制作一个简单的部门员工知识分享的python抽取脚本
    【Mybatis】XML配置实现增删改查
    NIO,AIO,BIO
  • 原文地址:https://www.cnblogs.com/waw/p/2162859.html
Copyright © 2020-2023  润新知