Валидация в MVC 3 без модели

У меня есть вопрос о проверке в 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);
            }
        });
    }
 Dan15 июн. 2012 г., 18:11
да. Если он не проверяется, он не должен вызывать команду ajax.
 NinjaNye15 июн. 2012 г., 18:16
Почему вы не можете использовать модель и аннотации данных?
 Doug Chamberlain15 июн. 2012 г., 19:19
Действительно ли это MVC, если у вас нет модели? Что плохого в том, чтобы просто создать модель, даже если для модели нет бэкэнда данных? Он по-прежнему позволяет использовать связующие модели по умолчанию для обработки данных вашего запроса. Мой .02 $
 Tin Can15 июн. 2012 г., 18:02
Влияет ли валидация, если она должна быть сохранена в вашей БД? Если так, то Javascript - это хорошо, но вам нужно проверить на стороне сервера. Обойти проверку на стороне клиента довольно легко.
 Tin Can15 июн. 2012 г., 18:17
Как сказал WooHoo, вам потребуется проверка на стороне сервера, независимо от проверки jQuery.

Ответы на вопрос(3)

Решение Вопроса

Другой вариант, который я хотел бы увидеть, это добавитьvalidation data attributes вручную к элементу 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"
})

В приведенном выше текстовом поле я добавил три типа проверок:required, type а такжеrange так легко, добавив атрибуты данных.unobtrusive validation library Отправленный Microsoft позаботится обо всем остальном.

Вы должны прочитать сообщения об ошибках и другие константы из одного места. Таким образом, вам не нужно копировать их, когда вы выполняете проверку на стороне сервера.

 03 мая 2015 г., 14:04
Большое спасибо, я изменил это немного, и это соответствует моей проверке требованийthis
 15 июн. 2013 г., 13:23
Большое спасибо за тебя, чувак

Вы все еще можете иметь модель представления только для того, чтобы установить правила проверки, а затем использовать небольшой ненавязчивый javascript, чтобы поймать отправку формы для выполнения вашего сообщения ajax.

ViewModel

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; }
}

Controller

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

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>
}

Вы можете использовать jQuery.validate и использовать некоторые встроенные методы проверки.
jQuery.validate

Хотя это может быть излишним для того, что вы делаете, и все равно потребует от вас проверки на стороне сервера.

Ваш ответ на вопрос