2012-12-06 50 views
5

我试图获得一个循环来发布由created_at每天分组的视频。按天创建集群_At

例如:

2012年12月5日 - 视频9 视频8 视频7

2012年12月4日 - 视频6 视频5

2012年12月3日 - 视频4 视频3 视频2 视频1

videos_controller:

def index 
    @title = 'Hip Hop Videos, Breaking News, Videos, And Funny Shxt | HOTDROPHIPHOP' 
    @description = '' 
    @videos = Video.all 
    @days = Video.where(:created_at == Time.today) 
    end 

查看文件:

<% @days.each do |day| %> 

    <div class="video-date">December 4, 2012</div> 

    <% @videos.each do |video| %> 
    <% end %> 

<% end %> 

我还需要获得该div显示当天的日期,以及。

我周围搜索,找不到解决方案,并尝试了group_by(这似乎是最干净的),但无法让它工作。我在Rails上有点生疏,因为我几个月没碰它。

回答

11

你可以做T他:

@videos = Video.where(Video.arel_table[:created_at].gteq(some_date_value)) 
@video_days = @videos.group_by {|video| video.created_at.to_date } 

@video_days将在{some_date_value: [{video1}, {video2}, etc], next_date_value: [{video3}, {video4}, etc], etc...}形式的哈希值。

由于您在created_at字段中调用.to_date,因此它会放弃所有时间信息,从而有效地按天分组所有内容。

可以遍历它想:

​​
+0

看起来是最好的方式,谢谢!但是,strftime有问题。给我错误:未定义的方法'strftime'为#<枚举器:星期六,2012年12月01日:step(Thu,2012年12月6日,1)>。显示为未定义的方法。 –

+0

你是如何建立你的循环?我在rails console本地执行此操作:'@ video_days.each {| date,video | date.class}'它正在打印'Date'。这应该工作。 –

+0

嗯......给我一个语法错误|而不是} –

1

首先,仅从今天打电话视频,然后遍历所有视频是没有意义的。

我会尝试这种方式:

控制器

@videos = Video.all(:conditions => ["created_at >= ?", Date.today.at_beginning_of_month]) 

查看

<% Date.today.at_beginning_of_month.upto(Date.today).each do |date| %> 
    <%= date %>: <%= @videos.select{|u| u.created_at == date }.title %> 
<% end %> 

它应该给你 “日期:视频标题” 视频列表的实际月份。

1

假设你正在使用MySQL和视频有属性标题 我张贴下面的代码,以帮助您把握逻辑(当然这需要重新理)

控制器

@videos = {} 
videos = Video.order("DATE(created_at) DESC, title ASC").select("DATE(created_at) as created_at, title, id") 

videos.collect{|x| @videos[x.created_at.to_s] = @videos[x.created_at.to_s] ? @videos[x.created_at.to_s] << x.title : [x.title] } 

视图

<% @videos.each do |posted_date, videos| %> 
    <div class="video-date"><%= Date.parse(posted_date.to_s).strftime("%b %d, %Y") %> </div> 
    <%= videos.join(", ") %> 
<% end %> 
2

最好的办法是用宝石Groupdate

User.group_by_day(:created_at).count

允许您按天,周订货,小时