And*_*tad 2 csv xls ruby-on-rails
我的用户可以生成一些数据的报告,并决定他们想要的格式.
他们可以选择HTML,CSV或XLS
这是表单(省略了数据,这只是格式选择器)
<%= form_tag "/report", :method => :get %>
Format <select id='format' name='format'>
<option value='html' selected='selected'>View in browser (HTML)</option>
<option value='csv'>Export to CSV file</option>
<option value='xls'>Export to exel (XLS)</option>
</select>
<%= submit_tag "Make report", :class => 'submit' %>
Run Code Online (Sandbox Code Playgroud)
此表单适用于此操作
def report
#...Again omitting data stuff
respond_to do |format|
format.html
format.csv
format.xls
end
end
Run Code Online (Sandbox Code Playgroud)
我有相应的视图文件.
喜欢 report.xls.erb
在我的日志中,我得到了
Processing by ..Controller#report as XLS
Run Code Online (Sandbox Code Playgroud)
但是,浏览器无需扩展即可下载文件.
如果我将form_tag行更改为此.
<%= form_tag "/report.xls", :method => :get %>
Run Code Online (Sandbox Code Playgroud)
该文件获得.xls扩展名.
我已经设置了xls mime_types
如何在表单中设置格式?
这是来自不同的问题.
您可以设置标题以告知文件的浏览器名称.
format.xls do
response.headers['Content-Disposition'] = 'attachment; filename="' + filename + '.xls"'
render "report.xls.erb"
end
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1505 次 |
| 最近记录: |