Любая помощь с этим будет высоко ценится. У меня есть сетка данных и кнопка загрузки в моем интерфейсе. Когда пользователь выбирает строку в сетке и нажимает кнопку загрузки, он должен передать int id в качестве параметра моему методу загрузки на моем контроллере, что вызывает дальнейшую обработку.
Я пытался использовать Ajax / JQuery для этого, но, увы, я новичок и продолжаю получать 0, передаваемых контроллеру. Он правильно выбирает мой идентификатор, так как у меня есть предупреждение, которое отображает правильный идентификатор при каждом выборе. Я не получаю ошибок при осмотре в Chrome.
Пожалуйста, смотрите соответствующий код ниже:
// html
<form asp-controller="Home" asp-action="Download" method="get">
<div id="downloadButton"></div>
</form>
// JQuery таблица данных на мой взгляд:
$("#gridContainer2").dxDataGrid({
dataSource: DevExpress.data.AspNet.createStore({
loadUrl: url + "/GetLoadHistory",
key: "loadId"
}),
selection: {
mode: "single"
},
hoverStateEnabled: true,
paging: {
pageSize: 10
},
editing: {
mode: 'row',
},
onSelectionChanged: getLoadId
});
// JQuery работает с Ajax:
function getLoadId() {
var dataGrid = $("#gridContainer2").dxDataGrid("instance");
var loadId = dataGrid.getSelectedRowKeys();
console.log("Load ID: " + loadId);
download(loadId);
}
function download(loadId) {
$("#downloadButton").dxButton({
text: "Download Selected",
type: "normal",
icon: "/favicon.ico",
contentType: "application/json; charset=utf-8",
dataType: "json",
useSubmitBehavior: true,
onClick: function (e) {
$.ajax({
url: 'https://localhost:44346/home/Download/',
data: { LoadID: loadId}
}).done(function () {
DevExpress.ui.notify("Downloading results for Load ID: " + loadId, "info", 1500);
});
}
});
};
// метод загрузки на домашний контроллер:
[HttpGet]
public async Task<IActionResult> Download(int loadId)
{
//always 0...
Console.WriteLine("Load ID passed from UI:" + loadId);
//further processing
}