如何使用CForm创建子表单数组?

时间:2012-09-29 18:35:16

标签: yii

我有一个模型数组,所有模型都是一个类的实例。我需要创建一个包含与数组中的模型对应的子表单的表单。

必须使用CForm,因为我已经做了一个很好的小扩展,它可以渲染CJuiTabs中的子表单。在POST参数名称错误的代码中,因为它们以数组中模型类的名称为前缀。

下面您可以看到生成的HTML代码片段。看那些YPageInfo [...]命名的输入?这就是问题 - 服务器只接收一组带有此前缀的输入。

<div style="visibility:hidden"><input type="hidden" value="1" name="yform_20bd4d2c" id="yform_20bd4d2c" /></div>
<div class="row field_name">
<label for="YPageRevision_name">Name</label>
<input name="YPageRevision[name]" id="YPageRevision_name" type="text" maxlength="45" />

</div>
<div class="row field_parent_id">
<label for="YPageRevision_parent_id">Parent Id</label>
<input id="YPageRevision_parent_id_hidden" name="YPageRevision[parent_id]" type="hidden" /><input id="YPageRevision_parent_id" type="text" value="" name="autocomplete-field" />

</div>
<div id="yw1">
<ul>
<li><a href="#enSubFormTab" title="enSubFormTab">en</a></li>
<li><a href="#ruSubFormTab" title="ruSubFormTab">ru</a></li>
</ul>
<div id="enSubFormTab"><div class="row field_title">
<label for="YPageInfo_title" class="required">Title <span class="required">*</span></label>
<input name="YPageInfo[title]" id="YPageInfo_title" type="text" maxlength="256" />

</div>
<div class="row field_content">
<label for="YPageInfo_content" class="required">Content <span class="required">*</span></label>
<textarea name="YPageInfo[content]" id="YPageInfo_content"></textarea>

</div>


</div>
<div id="ruSubFormTab"><div class="row field_title">
<label for="YPageInfo_title" class="required">Title <span class="required">*</span></label>
<input name="YPageInfo[title]" id="YPageInfo_title" type="text" maxlength="256" />

</div>
<div class="row field_content">
<label for="YPageInfo_content" class="required">Content <span class="required">*</span></label>
<textarea name="YPageInfo[content]" id="YPageInfo_content"></textarea>

</div>


</div>
</div>

<div class="row buttons"><input name="submit" type="submit" value="Create" />
</div>

1 个答案:

答案 0 :(得分:0)

我找到了一种方法来做我需要的事情。

在子表单的elements属性中,声明了一些输入。在那里声明的每个标准输入元素都有一个CFormInputElement的实例,因此它具有attributes属性。在这里,您可以设置任何HTML属性,该属性将在结果输入标记中呈现。我在这里放置了自定义name属性,并在循环中更改它,在那里我为主CForm创建子表单配置项。

也许有更好的方法?