我已經實現了此自定義json轉換器,根據收到的數據轉換類型,但似乎從未被調用過。該操作是否執行本地分析,而我的轉換器沒有被使用?在將數據從ajax發佈到控制器後未調用自定義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>
這是因爲JSON可能會發布該屬性的數組或字符串。如果是這樣,那麼在發送它之前,可以更容易在JavaScript中執行if(!(field instanceof Array)){field = [field]}'! –
@CallumLinington優秀的解決方案,謝謝。它不可能比這更簡單 –
回答這個問題,所以我可以將它標記爲您的解決方案,再次感謝您 –