我有一个数据结构,其中一个主题有很多问题(一对多),一个问题有很多答案(一对多).
我已经将问题设置为主题形式的嵌入式集合,并且由于菜谱条目的原因,我已经完成了100%的工作.
当我尝试开发这个以在问题表单中嵌入答案表单的集合时,我遇到了问题.
包含顶级原型表单的data-prototype属性在其中具有完整的表单深度,因此包括问题和答案的原型.但它__name__为每个级别使用相同的占位符.
<div id="topic_questions___name__">
<div class="control-group">
<label for="topic_questions___name___questionText" class="control-label">question</label>
<div class="form-row-errors"></div>
<div class="controls">
<textarea id="topic_questions___name___questionText" name="topic[questions][__name__][questionText]" required="required" class="input-block-level"></textarea>
</div>
</div>
<div class="control-group">
<label class="control-label">answers</label>
<div class="controls">
<div id="topic_questions___name___answers" data-prototype="<div class="control-group"><label class="control-label">__name__label__</label><div class="controls"><div id="topic_questions___name___answers___name__"><div class="control-group"><label for="topic_questions___name___answers___name___answerText" class="control-label">option</label><div class="form-row-errors"></div><div class="controls"><input type="text" id="topic_questions___name___answers___name___answerText" name="topic[questions][__name__][answers][__name__][answerText]" required="required" maxlength="255" /></div></div><input type="hidden" id="topic_questions___name___answers___name___sortOrder" name="topic[questions][__name__][answers][__name__][sortOrder]" /></div></div></div>"></div>
</div>
</div>
Run Code Online (Sandbox Code Playgroud)
您可以在底部看到真正的长行,我猜这是答案形式的原型 - 原型(!).我无法看到只替换问题相关的[__name__]占位符而不是答案相关的占位符.
做得很正常
var newForm = prototype.replace(/__name__/g, collectionHolder.children().length);
Run Code Online (Sandbox Code Playgroud)
当创建问题表单的实际实例时,当然会替换__name__具有相同值的所有实例,因此当为"答案"表单创建数据原型时,它已经替换了所有占位符.
当我点击添加一个真实的问题表单时,这就是数据原型在答案表单中的样子
<div class="control-group">
<label class="control-label">1label__</label>
<div class="controls">
<div id="topic_questions_1_answers_1">
<div class="control-group">
<label for="topic_questions_1_answers_1_answerText" class="control-label">option</label>
<div class="form-row-errors"></div>
<div class="controls">
<input type="text" id="topic_questions_1_answers_1_answerText" name="topic[questions][1][answers][1][answerText]" required="required" maxlength="255" />
</div>
</div>
</div>
</div>
Run Code Online (Sandbox Code Playgroud)
正如您所看到的,__name__占位符根本没有特征 - 在创建问题表单时,它已被问题表单的计数替换.
是否有可能通过Symfony提供的机制实现这种多深度嵌入式集合?
只要它试图为每个"级别"使用相同的占位符,那么我就看不出如何.
Wai*_*... 12
你是否至少使用Symfony 2.1?如果是这样,您可以__name__使用属性更改标签prototype_name:
http://symfony.com/doc/master/reference/forms/types/collection.html#prototype-name
在你的形式:
->add('answers', 'collection', array(
'type' => new AnswerType(),
'allow_add' => true,
'prototype_name' => 'another_name'
))
Run Code Online (Sandbox Code Playgroud)