我很好奇人们使用 AR 的 to_xml() 从控制器构建非实体字段的经验(例如,不是您正在序列化的模型的属性,但可能是利用过程中的属性)。
to_xml 似乎为此提供了一些选项。
一种是通过传递对正在操作的对象上的方法的引用:在序列化过程中,调用这些方法并将它们的结果添加到生成的文档中。我想避免这条路径,因为某些生成的数据虽然取决于对象的属性,但可能超出模型本身的范围——例如,构建特定项目“显示”操作的 URL。另外,它需要太多的深谋远虑。我希望能够通过调整控制器中的 to_xml 代码来更改结果文档。我也不想在对象中声明一个方法的麻烦。
在每个对象中覆盖 to_xml 也是如此。
其他两个选项似乎更符合要求:一个是通过在生成这些字段的序列化选项中传递 procs,另一个是通过传递一个在序列化对象属性后将产生的块。这些提供了我正在寻找的那种调用点自定义,此外,它们的声明将范围绑定到控制器,以便它们可以访问与控制器相同的东西,但是这些方法似乎受到严重限制:AFAICT 它们不包含对正在序列化的对象的引用。它们包含对构建器对象的引用,当然我猜你可以在块/过程中解析并找到已经序列化的属性并使用它们,但这是一种长篇大论,或者至少是不安和次优的。
如果我在这里错了,请纠正我,但是如果您必须访问对象本身,那么在序列化一个或多个对象时使用 procs/blocks 有什么意义。
无论如何,请告诉我我错了,因为我似乎必须在这里忽略一些东西。
哦,是的,我知道我可以写出我自己的观点。我正在尝试利用 respond_to 和 to_xml 来实现最少的额外文件/行。(不过,当我无法弄清楚如何使用 AR 的序列化来做到这一点时,我就采用了这种方法。)
**EDIT 3.29.09——我刚刚向 Rails 提交了一个补丁。如果您有兴趣,请提供一些支持:) https://rails.lighthouseapp.com/projects/8994-ruby-on-rails/tickets/2373-record-sensitive-procs-for-to_xml