1

一部のデータを含む 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
4

1 に答える 1

1

コードを次のように更新すると、動作します..試してみてください!!

function x() {

var obj = jQuery("input:checked").map(function() { return jQuery(this).parents('tr').attr('id'); });

var myAjaxVariable = null;
var arr = jQuery.makeArray(obj);
var data = arr.join(',');


$.ajax({
 url : '<%= url_for :action => "export_to_csv" %>',
 type : 'POST',
 data : {data:data},
 dataType : 'json',
 async : false,
     success : function(response) {myAjaxVariable = response;},
     error : function (request, status, error) {
            alert(request.responseText);
        }       
  });   

window.open( "data:text/csv;charset=utf-8," + escape(myAjaxVariable))  


}
于 2012-10-08T09:20:25.763 に答える