一部のデータを含む csv ファイルをエクスポートしようとしています。ビュー テーブル (jqGrid) からいくつかの行を選択し、csv 形式でエクスポートした後、ajax 呼び出しを行っています。問題は ajax 呼び出しが成功した後、フィルター処理されたデータがダウンロード オプションではなく警告メッセージとして表示されることです?? 何か案は??
コードを表示:
function x() {
var obj = jQuery("input:checked").map(function() { return jQuery(this).parents('tr').attr('id'); });
var arr = jQuery.makeArray(obj);
var data = arr.join(',');
$.ajax({
url : '<%= url_for :action => "export_to_csv" %>',
type : 'POST',
data : {data:data},
dataType : 'json',
success : function(response) {
alert("Details saved successfully!!!");
},
error : function (request, status, error) {
alert(request.responseText);
}
});
}
コントローラーコード:
def export_to_csv
require 'fastercsv'
data = params['data'].split(',')
@gos = GoSe.find(:all, :conditions => [ "id IN (?)", data])
csv = FasterCSV.generate do |line|
cols = ["ID","Details","PartnerCode","Sece","Date","Partner","Person","TaxName","TaxID"]
line << cols
@gos.each do |entry|
line << [entry.id, entry.description, entry.code, entry.ellipsis, entry.oDate, entry.name, entry.people_name, entry.tax_name, entry.tax_id ]
end
end
send_data(csv,
:type => 'text/csv; charset=iso-8859-1; header=present',
:disposition => "attachment; filename=go_data_#{Time.now.strftime('%d-%m-%y--%H-%M')}.csv")
end