我尝试在模式中以奏鸣曲呈现我的管理员类的列表操作,但我找不到正确的方法?有人可以帮我吗?我只想要数据网格,而不是所有页面(菜单、顶栏等)。实际上我是这样做的:
<a href="#" class="btn btn-sm btn-default" data-toggle="modal" data-target="#basicModal1">En Cours modal</a>
<div class="modal fade" id="basicModal1" tabindex="-1" role="dialog" aria-labelledby="basicModal" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>
<h4 class="modal-title" id="myModalLabel">Modal title</h4>
</div>
<div class="modal-body">
{{render (controller('MonBundle:Controller:list',{'id':object.id}))}}
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
</div>
</div>
</div>
</div>
但是我在渲染时遇到了此错误:
Error: Call to a member function getRelativePath() on null
显示整个页面是因为您包含标准控制器操作的模板。 Sonata 使用app.request.isXmlHttpRequest
的条件来检测视图是以模式(通过 AJAX)还是以标准方式打开的。
因此,您可以通过以下步骤解决问题:
1)在按钮单击时绑定JS功能(打开模态)。
2) 单击按钮时,加载 URL 并将其响应正文粘贴到.modal-body
网址: {{ path('your-list-action-name', {'id': object.id}) }}
当您从页面向列表中添加新记录时,它将解决问题,但列表将显示旧记录(因为在您的代码段中,列表在模态首次呈现时呈现一次)。
其他信息可以在Sonata的ORM管理捆绑包(如果您使用ORM)中找到Resources/views/CRUD/edit_orm_many_association_script.html.twig