我有一个表单,其中包含一个名为"price"的元素。我使用"float"验证器来验证这个元素。问题是当我插入时,例如:
12,50=>它是有效的,但当我试图将它保存在DB(mysql)上时,它被保存为"12.00"
所以我想把十进制字符从","改为"."。有人知道怎么做吗??
注意。如果我放:
$price->addValidator('Float', 'de')
或
$validator = new Zend_Validate_Float(array('locale' => 'de'));
$price->addValidator($validator)
它不起作用。
您可以使用过滤器Zend_filter LocalizedToNormalized to it将根据用户的区域设置对本地化价格进行标准化。
一个典型的价格要素是这样的:
$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);
当然,您可以对其进行改进,并添加所需的验证器/过滤器。