【问题标题】:Validation in MVC 3 without a Model没有模型的 MVC 3 中的验证
【发布时间】:2012-06-18 17:38:59
【问题描述】:

我对 mvc3 中的验证有疑问。内置验证看起来很棒。但是,我不得不在一种情况下使用 javascript,导致它与外观和感觉不一致(警报窗口与漂亮的红色文本)。我们有一个表单,其中包含一些供用户输入的字段。提交时,一些 ajax 代码会触发一个链接,该链接映射到一个控制器方法,该控制器方法获取从表单提交的值并启动导致创建客户端数据库的进程。 问题是:由于没有模型直接映射到该表单上的字段,因此对字段(长度、字符等)进行验证的最佳方法是什么? 我的解决方案是编写一些 javascript 函数,但有更简洁的方法吗?

 <td>@Html.TextBox("NewClientId")</td>
...            

    <script language="javascript">
       function ValidateFieldLength(min, max, element) {
            var len = element.value.length;
            if (len < min || len > max)
                return false;
            else {
                return true;
            }
        }
        function createNewClient() {
            if (!ValidateFieldLength(3,3,document.getElementById('NewClientId'))) {
            alert("Invalid Client ID length");
            return;
        }
        $.ajax({
            url: '/api/Clients',
            type: 'PUT',
            data: JSON.stringify({
                ClientId: $('#NewClientId').val(),
                Name: $('#NewClientName').val()
            }),
            contentType: 'application/json; charset=utf-8',
            success: function (reponse) {
                //alert(reponse.data.model.Id);
                alert("Database created");
            },
            error: function (err) {
                alert(err);
            }
        });
    }

【问题讨论】:

  • 验证是否会影响它是否应该存储到您的数据库中?如果是这样,Javascript 很好,但您需要验证服务器端。绕过客户端验证非常简单。
  • 是的。如果它没有验证,它不应该调用 ajax 命令。
  • 为什么不能使用模型和数据注释?
  • 正如 WooHoo 所说,无论 jQuery 验证如何,您都需要服务器端验证。
  • 没有Model真的是MVC吗?仅仅创建一个模型有什么问题,即使模型没有数据后端?它仍然允许您利用默认的模型绑定器来处理您的请求数据。我的 .02$

标签: javascript asp.net-mvc c#-4.0 asp.net-mvc-4


【解决方案1】:

我会看到的另一个选项是将 验证数据属性 手动添加到 html 元素。通过这种方式,您可以避免在服务器端和客户端重复错误消息和其他属性。

例如

@Html.TextBox("NoOfJoinees", "", new 
{ 
   size = 5,  
   data_val_required="No. of joinees is required",
   data_val_number = "The field No. of joinees must be a number.",
   data_val_range = "No. of joinees should be minimum 2 and not more than 10",
   data_val_range_max="10",
   data_val_range_min="2"
})

在上面的文本框中,我添加了三种类型的验证:requiredtyperange,通过添加数据属性很容易。微软提供的不显眼的验证库将负责其余的工作。

您应该从一个地方读取错误消息和其他常量。因此,当您在服务器端进行验证时,您不需要复制它们。

【讨论】:

  • 非常感谢,我修改了这个,这符合我的要求检查this
【解决方案2】:

您仍然可以拥有一个视图模型来设置验证规则,然后使用一些不显眼的 javascript 来捕获表单提交以执行您的 ajax 发布。

视图模型

public class YouViewModel
{
    [DisplayName("Client name")]
    [Required()]
    public string NewClientName { get; set; }

    [DisplayName("Client id")]
    [StringLength(3, MinimumLength = 3, ErrorMessage = "{0} must be 3 characters")]
    public string NewClientId { get; set; }
}

控制器

public ActionResult YourAction()
{
    return View() //Note that you don't even need to pass a view model to the view
}

查看

@model Namespace.YouViewModel

@using (Html.BeginForm())
{
    <div class="form-body">
        @Html.ValidationSummary()

        <div class="control-group">
            @Html.LabelFor(x => x.NewClientName )
            @Html.TextBoxFor(x => x.NewClientName , new { @class = "span3" })
        </div>

        <div class="control-group">
            @Html.LabelFor(x => x.NewClientId )
            @Html.PasswordFor(x => x.NewClientId , new { @class = "span3" })
        </div>
    </div>
}

【讨论】:

    【解决方案3】:

    您可以使用 jQuery.validate 并使用一些内置的验证方法。
    jQuery.validate

    虽然对于您所做的事情可能有点过头了,但仍然需要您进行服务器端验证。

    【讨论】:

      猜你喜欢
      • 2011-12-24
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多