我有一系列会员资格。每个会员都是一个团体。我需要按照组的名称对这个成员数组进行排序。我尝试了很多不同的方法,最新的方法是:
@memberships.sort_by! { |m| m.group.name }
但是,这并不是按名称排序的。它似乎是随机排序数组。
@memberships等于:
[
{
id: 2141,
user_id: 491,
group_id: 271,
member_type: "member",
group: {
id: 271,
name: "Derek's",
privacy: "open",
bio_image_url: "/bio_images/medium/missing.png?1340285189",
member_count: 1,
upcoming_checkins_count: 0
}
},
{
id: 2201,
user_id: 221,
group_id: 291,
member_type: "member",
group: {
id: 291,
name: "Rounded Developement",
privacy: "closed",
bio_image_url: "/groups/medium/291/bioimage.jpg?1340736175",
member_count: 7,
upcoming_checkins_count: 0
}
}
]
注意:这确实有效 - > @ memberships.sort_by! {| m | m.group.id}
它将基于group.id对数组进行排序,所以它可能与按字母顺序排序有关吗?
非常感谢任何帮助。
答案 0 :(得分:68)
@memberships.sort_by!{ |m| m.group.name.downcase }
答案 1 :(得分:3)
排序方法是一个选项吗?
ary.sort{ |a,b| a[:group][:name] <=> b[:group][:name] }
答案 2 :(得分:1)
我看不到你的代码是如何工作的。我无法使用m.group.name
这是一个有效的语法
@memberships.sort_by!{ |m| m[:group][:name] }