如何控制CakePHP表单中错误消息div的显示位置?

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了如何控制CakePHP表单中错误消息div的显示位置?脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
所以我理解,如果您根据Model的验证器验证错误消息,Cake PHP自动错误消息加载到视图中.我正在尝试设置日期保管箱验证,我想控制错误消息显示的位置.

在提交验证表格之前:

<div class="input text required">
<label for="UserEmail">Email</label>
<input name="data[User][email]" maxlength="50" tyPE="text" id="UserEmail">
</div>

验证后,错误显示在此处:

<div class="input text required error">
<label for="UserEmail">Email</label>
<input name="data[User][email]" maxlength="50" type="text" value="" id="UserEmail" class="form-error">
<div class="error-message">An email is required</div>
</div>

有可能控制它,我可以把它显示在这里吗?

<div class="input text required error">
<div class="error-message">An email is required</div>
<label for="UserEmail">Email</label>
<input name="data[User][email]" maxlength="50" type="text" value="" id="UserEmail" class="form-error">
</div>

或者在这里

<div class="error-message">An email is required</div>
<div class="input text required error">
<label for="UserEmail">Email</label>
<input name="data[User][email]" maxlength="50" type="text" value="" id="UserEmail" class="form-error">
</div>

解决方法

在视图中:

1)禁用自动错误显示

echo $this->Form->create('Mymodel',array(
    'inputdefaults' => array(
        'error' => false
    )
));

2)从$this-> validationErrors获取当前表单错误

3)通过$this->Form->error()将您自己的标记或Cake的标记显示在您喜欢的位置

更新:
我误解了你原来的问题.可以通过create()调用(应用于所有字段)或input()调用(针对单个字段)指定元素的顺序:

echo $this->Form->create('Mymodel',array(
    'inputDefaults' => array(
        'format' => array('before','error','label','between','input','after')
    )
));

以上将在标签div之前放置错误div.您可以按照自己喜欢的顺序重新排列该数组.

脚本宝典总结

以上是脚本宝典为你收集整理的如何控制CakePHP表单中错误消息div的显示位置?全部内容,希望文章能够帮你解决如何控制CakePHP表单中错误消息div的显示位置?所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。