使用jQuery非同步傳遞Model到控制器方法,並非同步返回錯誤資訊

來源:互聯網
上載者:User

標籤:style   blog   class   code   java   c   

需要通過jquery傳遞到控制器方法的Model為:

    public class Person
    {
        public string Name { get; set; }
        public int Age { get; set; } 
    }

 

使用下面這個類的Message屬性裝載成功或錯誤資訊,並最終轉換成json格式返回給視圖: 

    public class PersonVm
    {
        public string Message { get; set; } 
    }

 

控制器通過遍曆ModelState.Keys來顯示錯誤資訊。

      public ActionResult Demo()
        {
            return View();
        }
 
        [HttpPost]
        public ActionResult SavePerson(Person person)
        {
            if (ModelState.IsValid)
            {
                string message = string.Format("使用者姓名:{0},年齡:{1}", person.Name, person.Age);
                return Json(new PersonVm() {Message = message});
            }
            else
            {
                string errorMessage = "<div class=\"validation-summary-errors\">發生以下錯誤:<ul>";
                foreach (var key in ModelState.Keys)
                {
                    var error = ModelState[key].Errors.FirstOrDefault();
                    if (error != null)
                    {
                        errorMessage += "<li class=\"field-validation-error\">"+error.ErrorMessage+"</li>";
                    }
                }
                errorMessage += "</ul>";
                return Json(new PersonVm() {Message = errorMessage});
            }
        }    
 

 

視圖使用 $.toJSON()方法,把Model轉換成json格式傳遞給控制器方法。把對象轉換成json格式的jQuery擴充,在這裡。

@model MvcApplication1.Models.Person
@{
    ViewBag.Title = "Demo";
    Layout = "~/Views/Shared/_Layout.cshtml";
}
 
@Html.EditorForModel()
 
<input type="submit" value="儲存" id="personCreate"/>
<div>
    <span id="resultMessage"></span>
</div>
 
@section scripts
{
    <script src="~/Scripts/json.js"></script>
    <script type="text/javascript">
        $(function() {
            $(‘#personCreate‘).click(function() {
                var person = getPerson();
 
                if (person == null) {
                    alert("使用者名稱不可為空");
                    return;
                }
 
                var json = $.toJSON(person);
 
                $.ajax({
                    url: ‘@Url.Action("SavePerson","Home")‘,
                    type: ‘POST‘,
                    dataType: ‘json‘,
                    data: json,
                    contentType: ‘application/json; charset=utf-8‘,
                    success: function(data) {
                        var message = data.Message;
                        $("#resultMessage").html(message);
                    }
                });
            });
        });
 
        function getPerson() {
            var name = $(‘#Name‘).val();
            var age = $(‘#Age‘).val();
            return (name == "") ? null : { Name: name, Age: age };
        }
    </script>
}
 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.