i'am using class library for my Models and create my controllers in Area now i want to use remote validation but it's not working,actually it's not rendered.
my model in Models class library
[System.ComponentModel.DataAnnotations.RegularExpression(@"(?=.*[a-zA-Z0-9]).{4,20}$", ErrorMessage = "error")]
[System.ComponentModel.DataAnnotations.Required(ErrorMessage = "error")]
[System.Web.Mvc.Remote("UserNameExist","AdminUser","Admin",ErrorMessage="error")]
public string UserName { get; set; }
my controller in Admin Area
[HttpPost]
public JsonResult UserNameExist(string UserName)
{
using (DataBaseContext dbContext = new DataBaseContext())
{
var user = dbContext.Users.SingleOrDefault(current => current.UserName == UserName);
return Json(user == null);
}
}
also i was added jquery and jquery.validation and jquery.validate.unobtrusive and i was added this to my webconfig
<add key="ClientValidationEnabled" value="true" />
<add key="UnobtrusiveJavaScriptEnabled" value="true" />
Updated
rendered html is :
<input class="form-control directionEn valid" data-val="true" data-val-regex="error" data-val-regex-pattern="(?=.*[a-zA-Z0-9]).{4,20}$" data-val-required="error" id="UserName" name="UserName" placeholder="User Name" type="text" value="">
there is not attribute for remote validation
User View:
@model Models.User
@section Scripts
{
<script src="~/Scripts/jquery.validate.min.js"></script>
<script src="~/Scripts/jquery.validate.unobtrusive.min.js"></script>
}
<div class="row">
<div class="col-lg-6 col-lg-offset-3 col-md-6 col-md-offset-3">
<div class="form-group">
<a class="btn btn-success" href="/Admin/AdminUser/List">List</a>
</div>
</div>
</div>
<div class="row">
<div class="col-lg-6 col-lg-offset-3 col-md-6 col-md-offset-3">
<div class="panel panel-default">
<div class="panel-heading">
<h4>Add New User</h4>
</div>
<div class="panel-body">
@using (Html.BeginForm("Add", "AdminUser", null, FormMethod.Post, new { enctype = "multipart/form-data" }))
{
@Html.Raw(System.Web.HttpUtility.HtmlDecode((Html.ValidationSummary(true, "", htmlAttributes: new { @class = "alert alert-danger" }) ?? (object)"").ToString()))
<div class="form-group">
<label>
UserName
</label>
@Html.TextBoxFor(model => model.UserName, htmlAttributes: new { @class = "form-control directionEn", @placeholder = "User Name" })
@Html.ValidationMessageFor(model => model.UserName, "", htmlAttributes: new { @class = "validationError" })
</div>
}
</div>
</div>
</div>
</div>
what's wrong in my code ???