1

以下代码生成一个ModelAdminfor MyDataObject。添加时MyDataObject编辑表单为空,因为many_many只有在保存后才能看到关系。

class TestAdmin extends ModelAdmin {
    static $managed_models = array('MyDataObject');
    static $url_segment = 'testadmin';
    static $menu_title = 'TestAdmin';
}

class MyDataObject extends DataObject {
    private static $many_many= array('MyOtherDataObjects' => 'MyOtherDataObject');
}

class MyOtherDataObject extends DataObject {
    private static $db = array('Name' => 'Varchar(255)');
    private static $belongs_many_many = array('MyDataObjects' => 'MyDataObject');
}

有什么方法可以many_many立即建立关系吗?

如果没有,是否有一种方法可以创建对象,然后在没有保存关系的情况下将其删除?

4

1 回答 1

1

如果我理解正确,你的包可以有很多过滤器,一个过滤器可以被不同的包使用。那么你在包和过滤器之间就有了多对多的关系。产品列表是动态的,您可以每次计算。

您的用户应该以某种方式引用包,因此它应该具有属性名称,并且您至少有一个输入框来添加新包(而不是现在的空白屏幕)。

更新

您描述的行为是正确且预期ManyManyList的。状态与数据库同步,因此在您决定将列表存储在开箱即用的数据库中之前,您不能将项目仅存储在内存中。

您可以Add New用您自己的实现替换按钮以自动创建新对象,将其保存在数据库中并重定向到编辑屏幕。

于 2016-09-20T07:38:11.647 回答