【.NET框架】—— ASP.NET MVC數據驗證註解(三)

數據驗證註解:經過在Models層,經過註解特性對模型屬性,進行註解設置,來實現數據驗證的功能。前端

主要命名空間:System.ComponentModel.DataAnnotations正則表達式

1.1.ASP.NET MVC Required特性

Requierd特性:服務器

n  設置必填屬性,驗證是否填寫內容ui

n  服務端Model屬性添加[Required]spa

n  前端提示錯誤信息3d

@Html.ValidationMessageFor()code

示例代碼:orm

①在Models層上引入System.ComponentModel.DataAnnotations命名空間,併爲屬性添加[Required]約束blog

public class Student
    {
        [Required] //表示能夠在前臺展現姓名字段
        [DisplayName("姓名")]
        public string name { get; set; }
        [Required]
        [DisplayName("性別")]
        public string sex { get; set; }
        [Required]
        [DisplayName("年齡")]
        public int age { get; set; }
    }

②前端頁面加上對應的@Html.ValidationMessageFor(Model => Model.屬性)註解,表示對對應的參數須要驗證,會顯示錯誤信息;ci

<!--表示提交到本類對應的Controller控制器上-->
@using (Html.BeginForm())
{
<div>
    @Html.LabelFor(Model => Model.name)
    @Html.TextBoxFor(Model => Model.name)
    @Html.ValidationMessageFor(Model => Model.name)
</div>
<div>
    @Html.LabelFor(Model => Model.sex)
    @Html.TextBoxFor(Model => Model.sex)
    @Html.ValidationMessageFor(Model => Model.sex)
</div>
<div>
    @Html.LabelFor(Model => Model.age)
    @Html.TextBoxFor(Model => Model.age)
    @Html.ValidationMessageFor(Model => Model.age)
</div>
    <input type="submit" value="提交"/>
}

③對應的提交Controller增長[HttpPost]提交方式,傳入提交Model參數,顯示到界面上;

[HttpPost]
public ActionResult Contact(Student stu)
{
      return View(stu);
}

若是前臺頁面數據爲空,則會提示對應錯誤信息:

 

1.2.StringLength特性

StringLength特性驗證輸入字符串長度;

語法:

public class Student
    {
        [Required]
        //表示能夠在前臺展現姓名字段
        [DisplayName("姓名")]
        [StringLength(20, MinimumLength = 5)] //設置最大輸入長度爲20個字符串,最小輸入長度爲5個字符串
        public string name { get; set; }
        [Required]
        [DisplayName("性別")]
        public string sex { get; set; }
        [Required]
        [DisplayName("年齡")]
        public int age { get; set; }
    }

驗證顯示結果:

 

1.3.RegularExpression特性

RegularExpression表示正則表達式驗證特性;

使用方式:[RegularExpression(表達式)]

[RegularExpression("[a-zA-Z]{5,20}")]
public string name { get; set; }

驗證顯示結果:

 

1.4.ASP.NET MVC Range特性

Range特性:主要用於驗證數字類型的最大值和最小值;

使用方式:[Range(10,20)]

[Range(10, 20)] //限制年齡範圍必須是10-20歲
[Range(typeof(decimal), "10.0", "20.0")] //限制年齡範圍及類型
public int age { get; set; }

 

1.5.ASP.NET MVC Remote特性

Remote特性:主要是將屬性數據發送到服務器,進行服務器驗證後,返回信息

使用方式:[Remote(方法,控制器)]

Remote能夠在任意控制器中加入判斷的方法,在前端執行參數驗證時每次調用該控制器上的方法進行驗證,經過後返回視圖結果:

public class Student
{
      //Model類上面加上註解
      [Remote("CheakName", "Home")]
      [Required]
      [DisplayName("姓名")]
      public string name { get; set; }
}

遠端驗證方法:

 

 

1.6.自定義錯誤信息ErrorMessage

ErrorMessage註解屬性用於自定義錯誤信息顯示,

用法:

[Required(ErrorMessage=「錯誤信息」)]

public class Student
    {
        [Required(ErrorMessage="姓名不能爲空!")]
        [DisplayName("姓名")]
        public string name { get; set; }
         [Required(ErrorMessage="性別不能爲空!")]
        [DisplayName("性別")]
        public string sex { get; set; }
        [Required(ErrorMessage="年齡不能爲空!")]
        [DisplayName("年齡")]
        public string age{get;set;}
    }

 

1.7.Compare特性

Compare特性用於比較輸入的內容是否相同

用法:

[Compare(「屬性名稱」)]

示例:

@using (Html.BeginForm()) { 
<div>
    @Html.LabelFor(Model => Model.name)
    @Html.TextBoxFor(Model => Model.name)
    @Html.ValidationMessageFor(Model => Model.name)
</div>
  <div>
    @Html.LabelFor(Model => Model.name2)
    @Html.TextBoxFor(Model => Model.name2)
    @Html.ValidationMessageFor(Model => Model.name2)
</div>
    <input type="submit" value="保存" />
}

  public class Student
    {
        [Required(ErrorMessage="姓名不能爲空!")]
        [DisplayName("姓名")]
        public string name { get; set; }
        [Compare("name")]
        [Required(ErrorMessage = "姓名2不能爲空!")]
        [DisplayName("姓名")]
        public string name2 { get; set; }
    }

相關文章
相關標籤/搜索