我不会在这里重复我的问题,但是有更有效的方式来写这个吗?
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).
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。