我在使用多步骤表单时遇到了一些问题,因为包含只有单选按钮的表单的单个步骤的验证不起作用:(
我有一个简单的属性类型,它代表一个单选按钮值:
class Step1Data extends \TYPO3\CMS\Extbase\DomainObject\AbstractEntity {
/**
* type
*
* @var string
* @validate NotEmpty
*/
protected $type;
/**
* Returns the type
*
* @return string $type
*/
public function getType() {
return $this->type;
}
/**
* Sets the type
*
* @param string $type
* @return void
*/
public function setType($type) {
$this->type = $type;
}
}
此步骤的流体标记如下所示:
<f:layout name="Default" />
<f:section name="main">
<f:form action="step1redirect" class="step1" name="step1data" object="{step1data}">
<f:render partial="FormErrors" arguments="{field: 'step1data.type'}" />
<label>
<f:form.radio property="type" value="type-1" />
type 1
</label>
<label>
<f:form.radio property="type" value="type-2" />
type 2
</label>
<f:form.submit value="next" />
</f:form>
</f:section>
此步骤的控制器操作是:
/**
* Step1
*
* @param \Fox\Example\Domain\Model\Step1Data $step1data
* @ignorevalidation $step1data
*/
public function step1Action(\Fox\Example\Domain\Model\Step1Data $step1data = NULL) {
if ($GLOBALS['TSFE']->fe_user->getKey('ses', 'step1data') && $step1data == NULL) {
$step1data = unserialize($GLOBALS['TSFE']->fe_user->getKey('ses', 'step1data'));
}
$this->view->assign('step1data', $step1data);
}
/**
* Step1 redirect action
*
* @param \Fox\Example\Domain\Model\Step1Data $step1data
*/
public function step1redirectAction(\Fox\Example\Domain\Model\Step1Data $step1data) {
$GLOBALS['TSFE']->fe_user->setKey('ses', 'step1data', serialize($step1data));
$GLOBALS['TSFE']->fe_user->storeSessionData();
$this->redirect('step2');
}
如果我将带有NotEmpty注释和流体文本字段的类型为string的示例第二个属性 name 添加到此表单,如:
<f:layout name="Default" />
<f:section name="main">
<f:form action="step1redirect" class="step1" name="step1data" object="{step1data}">
<f:render partial="FormErrors" arguments="{field: 'step1data.type'}" />
<label>
<f:form.radio property="type" value="type-1" />
type 1
</label>
<label>
<f:form.radio property="type" value="type-2" />
type 2
</label>
<!-- EXAMPLE second property -->
<f:render partial="FormErrors" arguments="{field: 'step1data.name'}"/>
<f:form.textfield property="name" />
<!-- EXAMPLE second property -->
<f:form.submit value="next" />
</f:form>
</f:section>
验证工作正常。如果我只有这个表单上的文本字段,验证也有效,但如果我只有这个表单上没有文本字段的单选按钮,则验证不起作用,并且因为step1data对象为空而出现错误。
我不知道这个奇怪问题的原因,希望你能帮助我吗?
答案 0 :(得分:0)
解决方案是单选按钮上方的隐藏输入字段,具有相同的属性名称:
<f:form.hidden property="type" />
<div class="group-block">
<label>
<f:form.radio property="type" value="wish1" />
type1
</label>
</div>
<div class="group-block">
<label>
<f:form.radio property="type" value="wish2" />
type2
</label>
</div>
首先,将检查并验证隐藏字段,如果选中单选按钮,则将覆盖type属性