Javascript:
Code: Select all
var currentSelection = [];
function selection_changed(selectedItems) {
var dataGrid = $("#myContainer").dxDataGrid("instance");
var data = selectedItems.selectedRowsData;
if (data.length > 0) {
currentSelection = data
.map((value) => `${value.Name}`)
} else {
currentSelection = [];
};
}
function create(e) {
$.ajax({
url: "@Url.Action("Register", "MyController")",
contentType: "application/json; charset=utf-8",
dataType: 'json',
type: 'POST',
data: JSON.stringify(currentSelection),
success: function (response) {
showToast("success");
},
error: function (xhr, status, error) {
showToast("error");
}
});
}
Code: Select all
["Name1","Name2"]
Code: Select all
[HttpPost]
public virtual ActionResult Register(object currentSelection)
Code: Select all
data: {currentSelection: JSON.stringify(currentSelection)}
Ich habe auch versucht, [FromBody] zum Controller hinzuzufügen, anstatt Objekt hat List oder string[] ausprobiert.
Nichts funktioniert. Ich erhalte jedes Mal den HTTP 400-Fehler. Wenn ich den Code in eine GET-Anfrage ohne Daten usw. geändert habe, funktioniert alles, also keine URL-/Kommunikationsprobleme.
Kann mir jemand dabei helfen?