我不会在这里重复我的问题,但是有更有效的方式来写这个吗?
def recruits_names names = [] for r in self.referrals do names << r.display_name end return names end
解决方法
使用
map
方法:
Returns a new array with the results of running block once for every element in enum.
def recruits_names self.referrals.map { |r| r.display_name } end
[更新]如Staelen在评论中所指出的,这个例子可以进一步缩短到:
def recruits_names self.referrals.map(&:display_name) end
为了好奇,这是因为&在跟随它的对象上调用to_proc(在方法调用中使用时),而Symbol实现to_proc来返回执行由块赋值的每个值上符号所指示的方法的Proc(参见the documentation).