我有这个表单元素:
$this->addElement('text', 'prezzo', array(
'label' => 'Prezzo (*)',
'filter' => '',
'description' => 'Il prezzo non è comprensivo di sconto, ma se previsto verrà calcolato',
'required' => true,
'validators' => array('Float'),
'placeholder' => 'Prezzo Pneumatico',
'class' => 'form-control'
));
如果我输入一个这样的数字24.50
我会在验证时出错,而如果我输入这样的数字24,50
我没有收到任何错误。
我认为问题出在Zend_Locale
Bootstrap.php
我设置此值:
protected function _initLocale() {
$locale = new Zend_Locale ( 'it' );
Zend_Registry::set ( 'locale', $locale );
}
可能有一个解决方案是过滤输入并将'.'
替换为','
。
你能救我吗?
答案 0 :(得分:3)
如果要在 en locale中验证,例如 24.50 将locale option设置为您的验证码。
$this->addElement('text', 'prezzo', array(
'label' => 'Prezzo (*)',
'filter' => '',
'description' => 'Il prezzo non è comprensivo di sconto, ma se previsto verrà calcolato',
'required' => true,
'validators' => array(array('Float', true, array('locale' => 'en'))),
'placeholder' => 'Prezzo Pneumatico',
'class' => 'form-control'
));
答案 1 :(得分:0)
我这样解决了:
<script type="text/javascript">
$(function(){
$('form[name=pneumatico]').find('input[name=prezzo]').keyup(function() {
$(this).val($(this).val().replace('.', ','));
});
$('form[name=pneumatico]').find('input[name=sconto]').keyup(function() {
$(this).val($(this).val().replace('.', ','));
});
}); </script>
由于