如果仅使用单选按钮,则TYPO3表单验证不起作用

时间:2015-07-14 08:30:39

标签: validation typo3 fluid extbase typo3-6.2.x

我在使用多步骤表单时遇到了一些问题,因为包含只有单选按钮的表单的单个步骤的验证不起作用:(

我有一个简单的属性类型,它代表一个单选按钮值:

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对象为空而出现错误。

我不知道这个奇怪问题的原因,希望你能帮助我吗?

1 个答案:

答案 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属性