在我的申请中,我有职位。每个位置都有一个父位置和多个子位置。如何导航树并找到同一代中的所有位置?
目前我有这个:
def org_chart_level
ps = self
level = 10
while ps do
break if ps.reports_to == nil
ps = ps.reports_to
level += 10
end
if self.reports_to
siblings = self.reports_to.responsible_for
else
siblings = [self]
puts siblings
end
"#{level}-#{siblings.index(self) + 1}"
end
这几乎可以工作,因为它可以给我一个职位的级别,它可以告诉我它是父母的哪个兄弟姐妹,但它不能告诉我它是一代中的哪个兄弟姐妹。
每个职位的预期水平。
1.1
-2.1
-3.1
-2.2
-3.2
实际水平:
1.1
-2.1
-3.1
-2.2
-3.1