发布到MVC4中的控制器

时间:2014-10-15 12:26:50

标签: javascript jquery asp.net-mvc-4

我在这里问了几个问题而没有任何可行的答案。我可能走错了轨道或者说错了。基本上,我要做的是在页面中加载VAR:

 var testModel = @Html.Raw(JSON.Encode(Model))

然后使用jQuery和JavaScript操作反映原始模型的testModel属性,然后将其发送回带有AJAX请求的控制器方法:

 $.ajax({
   datatype: 'json',
   data: testModel // ?? or some other way?
    // etc
 });

控制器:

 public ActionResult PostModel (ModelName model)  // or JsonResult
 {
     //do things
     return Json(model);  // or return View?
 }

任何帮助都将不胜感激。

我已经尝试过其他人在下面提出的建议,但事务仍然没有进入控制器方法。为什么不呢?

4 个答案:

答案 0 :(得分:1)

  

Ajax type指定请求的类型。 (GET或POST)DETAILS

$.ajax({
   type: 'POST',//or GET
   dataType: 'json',
   data: testModel // ?? or some other way?
    // etc
 });

答案 1 :(得分:0)

type代表您所要求的请求类型,而不是您将要返回的数据类型。 dataType是你应该拥有的POST字段中的type

 $.ajax({
   type: 'POST',
   dataType: 'json',
   data: testModel // ?? or some other way?
    // etc
 });

答案 2 :(得分:0)

基本上你是通过javascript发布数据所以成功时你需要一个Json对象来解析 所以你需要return Json(model)

public ActionResult PostModel (ModelName model)  // or JsonResult
 {
     //do things
     return Json(model);  
 }

和您的JS

 $.ajax({
   type: 'POST',
            url: '{somecontroller}/{someaction}',
            cache: false,
            contentType: 'application/json; charset=utf-8',
            data:testModel, 
            success: function (object) {
                $.each(object, function (key, val) {
                  //do your stuff here
              })
        })

key将是Model Property name,而val将分别为其值


现在消除您的困惑"何时返回View?" 在ASP.NET MVC中,有三种方法可以将信息从控制器传递到视图。 我们使用Html助手生成html字段并将其与模型 绑定到Get/Post从视图到控制器的数据值

  • 作为强类型模型对象。 (特定型号)
  • 作为动态类型(使用@model动态)
  • 使用ViewBag

现在,当您使用html帮助程序时,您可以使用随其传递的对象模型返回视图,这将自动将视图中的数据填充为:

强类型模型对象

<%@ Page Title="#" Language="VB" MasterPageFile="#" Inherits="System.Web.Mvc.ViewPage(Of somemodel)" %>

将视图渲染为

Return View("your View Path", modelObject)

答案 3 :(得分:0)

以下是我采取的措施:

在页面(.cshtml)中:

 function SendJsonData() {
     localModel.itemNumber = $("#txtItemNumber").val();
     //  etc for the rest of the fields
     $.ajax({
        url: '@Url.Action("PostModel", "ItemControl")',
        data: JSON.stringify(localModel),
        dataType: 'json',
        cache: false,
        type: 'POST',
        contentType: 'application/json, charset=utf-8',
        success: function(data) {
            //do stuff
        },
        error: function () {
           alert('error');
        }
      });

然后在控制器中:

      [HttpPost]
      public JsonResult PostModel(ItemModel localModel)
      {
          //do stuff with data model
          return Json(localModel);
      }

这很好用,在我看来是使用MVC4及更高版本的大多数应用程序的方法。这样整个模型就在页面中,可以使用jQuery和JavaScript轻松操作,然后发送到控制器进行处理。这甚至可以是一个大型的复杂模型,我已经尝试过了。没有更多的帖子和页面闪烁和重写...