Как я мог передать параметр в метод экспорта CSV в контроллере MVC с Jquery/Ajax
На мой взгляд у меня есть кнопка для экспорта в CSV текущего представления данных. Это простая ссылка на метод в контроллере.
<input type="button" value="Exporter" id="btnexport" class="btnsearch" onclick="location.href='@Url.Action("ExportCSV", "AuditAddins")'" />
И метод контроллера
public void ExportCSV()
{
auditAddins = AddinsCache.AuditAddinsCache;
var sw = new StringWriter();
sw.WriteLine(String.Format("{0};{1};{2};{3};{4}", "Date", "AddinName", "IsAddinActive", "UserName", "PcName"));
foreach (var record in auditAddins)
{
sw.WriteLine(String.Format("{0};{1};{2};{3};{4}", record.Date, record.AddinList.AddinName, record.IsAddinActive, record.Users.UserName, record.Pc.PcName));
}
Response.Clear();
Response.AddHeader("Content-Disposition", "attachment; filename=Export.csv");
Response.ContentType = "text/csv";
Response.Write(sw);
Response.End();
}
Работает хорошо. Но мне нужно отправить параметр этому методу, потому что у меня есть три режима разработки, и у каждого есть свой порядок столбцов. Поэтому я создал скрипт jquery/ajax для отправки параметра.
$("#btnexport").click(function () {
var index = $('#CritID').find('option:selected').val();
var d = { chx: index}
$.ajax({
url: "/AuditAddins/ExportCSV",
type: "POST",
data: d,
success: function (data) {
alert("Export ok !");
},
});
});
Основная цель - изменить метод экспорта следующим образом:
public void ExportCSV(int chx)
{
...
switch (chx)
{
case 1:
sw.WriteLine(String.Format("{0};{1};{2};{3};{4}", "Date", "AddinName", "IsAddinActive", "UserName", "PcName"));
break;
case 2:
sw.WriteLine(String.Format("{0};{1};{2};{3};{4}", "Date", "UserName", "PcName","AddinName", "IsAddinActive"));
break;
...
}
Проблема в том, что у меня больше нет окна загрузки IE. Я пробовал с методом actionresult, он тоже не работает.
1 ответ
Вам не нужно использовать POST
отправить параметр.
Вместо этого вы можете добавить параметр в GET
запрос:
/AuditAddins/ExportCSV?index=2
и значение по умолчанию 1, если параметр не указан.
Чтобы отправить несколько параметров, вы можете использовать &
разделить их:
/AuditAddins/ExportCSV?index=2¶m2=123
Это также должно решить проблему с окном загрузки.