我有一个名为“price”的元素的表单。我使用“float”验证器验证此元素。事情是我插入时,例如:
12,50 =>它是有效的,但当我尝试将其保存在DB(mysql)上时,它将保存为“12.00”
所以我想将小数字符从“,”更改为“。”。有谁知道怎么做?
请注意。如果我把:
$price->addValidator('Float', 'de')
或
$validator = new Zend_Validate_Float(array('locale' => 'de'));
$price->addValidator($validator)
它不起作用。
答案 0 :(得分:10)
您可以使用过滤器Zend_Filter LocalizedToNormalized来根据用户的区域设置将您的本地化价格标准化。
典型的价格元素就像这样:
$price = new Zend_Form_Element_Text('price');
$price->setLabel('Price:')
->setRequired(true)
->setAttribs(array('required name' => 'price', 'maxlength' => '12'))
->addFilter('StripTags')
->addFilter('StringTrim')
->addFilter('pregReplace', array('match' => '/\s+/', 'replace' => ''))
->addFilter('LocalizedToNormalized')
->addValidator('stringLength', true, array(1, 12))
->addValidator('float', true, array('locale' => 'en_US'))
->addValidator('greaterThan', true, array('min' => 0));
$this->addElement($price);
当然,您可以改进它并添加您需要的验证器/过滤器。