假设您的分类树由
{A:{A1:{A1I, A1II}, A2:{A2I}}, B:{B1:{B1I}, B2:{B2II}}}
符号 A->A1->A1I 描述了树中的路径。在这种情况下,路径是在 A 树中从其根 (A) 到叶 (A1I)。
如果您想将 foo 添加到 A->A1->A1I 分类,您可以使用foo.addTaxonomy(['A', 'A1', 'A1I'])
. 该函数的列表参数addTaxonomy
实际上表示分类树中的路径。接受的第二个参数addTaxonomy
是可选的,本质上定义了分类树的范围。所以,如果我要这样做
foo.addTaxonomy(['A', 'A1', 'A1I'], 'scope1')
foo.addTaxonomy(['A', 'A1', 'A1I'], 'scope2')
这会将 foo 放在范围 1 和范围 2 中的 A->A1->A1I 中。它们本质上是两种不同的树。你可能不需要这个。
以下是与您在问题中描述的树结构相关的一些示例:
添加到A->A1->A1II
foo.addTaxonomy(['A', 'A1', 'A1II'])
添加到 A2->A2I
foo.addTaxonomy(['A2', 'A2I'])
添加到 B->B1->B1I
foo.addTaxonomy(['B', 'B1', 'B1I'])
添加到 B2->B2I
foo.addTaxonomy(['B2', 'B2I'])
上面的 4 个示例分别创建了以 A、A2、B 和 B2 为根的树。
如果您不想定义分类单元的绝对路径,可以执行以下操作:
def taxonPath(taxonName) {
def currentTaxon = Taxon.findByName(taxonName)
def path = [currentTaxon.name]
while(currentTaxon.parent) {
currentTaxon = currentTaxon.parent
path = [currentTaxon.name] + path
}
return path
}
taxonomyService.createTaxonomyPath(['B', 'B2', 'B2I'])
def book = new Book(name:"hacky solution")
book.addToTaxonomy(taxonPath('B2I'))
这相当于book.addToTaxonomy(['B', 'B2', 'B2I'])
. 您还需要import com.grailsrocks.taxonomy.Taxon
将 taxonomyService 注入到您的工件中,例如 ( def taxonomyService
) 以使其工作。
该解决方案感觉有点笨拙且效率低下,但它确实有效。