使用 AJAX 将动态数据传递到 mvc 控制器

本文关键字:mvc 控制器 数据 AJAX 动态 使用 | 更新日期: 2023-09-27 18:36:58

如何通过AJAX调用将dynamic数据传递给MVC Controller

Controller

public JsonResult ApplyFilters(dynamic filters){
   return null;
}

AJAX调用:

$(':checkbox').click(function (event) {
    var serviceIds = $('input[type="checkbox"]:checked').map(function () {
        return $(this).val();
    }).toArray();
    //alert(serviceIds);
    $.ajax({
        type: 'GET',
        url: '/home/ApplyFilters',
        data: JSON.stringify({
            name: serviceIds
        }),
        contentType: 'application/json',
        success: function (data) {
            alert("succeeded");
        },
        error: function (err, data) {
            alert("Error " + err.responseText);
        }
    });
    //return false;
});

理想情况下,filters将包含serviceIds作为属性

例如像这样:filters.ServiceIds .我为日期范围提供了另一个过滤器,该过滤器将按如下方式添加:filters.DateRange .

服务器端将过滤器作为dynamic对象获取ApplyFilters()

使用 AJAX 将动态数据传递到 mvc 控制器

据我所知,默认的ASP MVC模型绑定器无法完成这样的事情。

幸运的是,有许多解决方案,其中有两个:

1.这是第一个,它会将您的JSON数据转换为IDictionary<string, object>实例,然后再将其传递给控制器操作。你最终会得到:

public JsonResult ApplyFilters(IDictionary<string, object> filters)
{
   return null;
}

2. 第二种方法使您的控制器操作能够接收 JsonValue 实例。使您的动作看起来像这样:

public JsonResult ApplyFilters([DynamicJson]JsonValue filters)
{
   return null;
}

3. 根据前面的教程,您可以创建自己的自定义模型绑定器,返回动态对象。以下代码取自第一个提案,并进行了修改以生成动态对象。这只是为了说明这个想法,不要按原样使用它:

public object BindModel(ControllerContext controllerContext, ModelBindingContext bindingContext)
{
    if (!controllerContext.HttpContext.Request.ContentType.StartsWith("application/json", StringComparison.OrdinalIgnoreCase))
    {
        return null;
    }
    controllerContext.HttpContext.Request.InputStream.Position = 0;
    using (var reader = new StreamReader(controllerContext.HttpContext.Request.InputStream))
    {
        var json = reader.ReadToEnd();
        if (string.IsNullOrEmpty(json))
        {
            return null;
        }
        dynamic result = new ExpandoObject();
        var deserializedObject = new JavaScriptSerializer().DeserializeObject(json) as IDictionary<string, object>;
        if (deserializedObject != null)
        {
            foreach (var item in deserializedObject)
            {
                ((IDictionary<string, object>)result).Add(item.Key, item.Value);
            }
        }
        return result;
    }
}

这些解决方案依赖于构建自定义模型绑定器来处理此特定方案:

  • 自定义模型绑定器只是 IModelBinder 接口的实现,负责解析 JSON 发布的数据并将其转换为另一种格式。
  • ASP MVC 框架被告知通过注册它们(使用 ModelBinders.Binders.Add 或使用专用属性 (CustomModelBinderAttribute) 来使用这些特定的自定义模型绑定器。