将数据从 ajax 发布到控制器后未调用自定义 JSON 转换器

本文关键字:调用 自定义 转换器 JSON 控制器 数据 ajax | 更新日期: 2023-09-27 17:56:14

我已经实现了这个自定义 json 转换器,以根据收到的数据转换类型,但似乎从未调用过它。操作是否执行本机解析,而我的转换器未被使用?

我的结果将发布到此操作中

[HttpPost]
public JsonResult saveCustomfields(CustomFields customfields)
{
}

public class Field
{
    public string _label { get; set; }
    public string _name { get; set; }
    public string _type { get; set; }
    public List<Option> option { get; set; }
}
public class Fields
{
    [JsonProperty("field")]
    [JsonConverter(typeof(SingleOrArrayConverter<Field>))]
    public List<Field> field { get; set; }
}
public class Formtemplate
{
    [JsonProperty("fields")]
    public Fields fields { get; set; }
}
public class CustomFields
{
    [JsonProperty("formtemplate")]
    public Formtemplate formtemplate { get; set; }
}

自定义转换器

public class SingleOrArrayConverter<T> : JsonConverter
{
    public override bool CanConvert(Type objectType)
    {
        return (objectType == typeof(List<T>));
    }
    public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
    {
        JToken token = JToken.Load(reader);
        if (token.Type == JTokenType.Array)
        {
            return token.ToObject<List<T>>();
        }
        return new List<T> { token.ToObject<T>() };
    }
    public override bool CanWrite
    {
        get { return false; }
    }
    public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
    {
        throw new NotImplementedException();
    }
}

阿贾克斯

<script>
    jQuery(document).ready(function ($) {
        var fbTemplate = document.getElementById('fb-template');
        var formBuilder = $(fbTemplate).formBuilder();
        $(".form-builder-save").click(function (e) {
            e.preventDefault();
            var x2js = new X2JS();
            var xml = formBuilder.data('formBuilder').formData;
            var json = x2js.xml_str2json(xml);
            alert(JSON.stringify(json));
            $.ajax({
                url: "saveCustomfields",
                type: "POST",
                data: JSON.stringify(json),
                contentType: "application/json; charset=utf-8",
                dataType: "json",
            });
        });
    });
</script>

将数据从 ajax 发布到控制器后未调用自定义 JSON 转换器

免责声明:这不是直接答案,而是替代解决方案

因此,我认为这是一个潜在解决方案的原因是因为此 C# 属性:

[JsonConverter(typeof(SingleOrArrayConverter<Field>))]
public List<Field> field { get; set; }

我将其作为单个项目或数组转换器阅读为列表。所以这在 JavaScript 中真的很容易。

因此,JavaScript 有一个漂亮的小技巧,使用文字和instanceof

if (!(field instanceof Array)) { // if field isn't an array
   field = [field]; // make it one
} 

这基本上是说,如果变量不是数组,那么让它成为一个数组。

这可能比让 C# 摆弄 JSON 更容易做到。

同样在我看来,我相信您应该始终在客户端和服务器之间传输最简单的JSON(反之亦然)。