我使用jquery动态创建一个文本框(基于用户选择)..有没有办法从zend表单为该文本框提供验证..?
问问题
219 次
1 回答
2
就在这里。
大多数学分都归于 jeremy kendall 参见http://www.jeremykendall.net/2009/01/19/dynamically-adding-elements-to-zend-form/
我解决它的方法是通过对添加获取表单元素的操作执行 jquery/ajax 调用,例如:
$.ajax({
type : "POST",
url : "/<controller>/addfield/",
success : function(newElements) {
// Insert new element before the submit button
$("#productsNew-submit-element").before(newElements);
}
});
它的作用是调用一个动作,该动作生成一个表单元素并返回您可以添加的 html
public function addfieldAction()
{
//use $ajaxContext = $this->_helper->getHelper('AjaxContext'); in the init to make it return html via ajax
$element = new Zend_Form_Element_Text("extraElement_1");
$element->setBelongsTo("yourForm");
$element->setLabel('myElementName');
/*
set other stuff like decorators or so
*/
//now create the html
$elements .= $element->__toString();
$this->view->fields = $elements;
}
之后,您将通过 ajax 在表单中获得一个新元素
现在,当您提交时,您必须再次执行此操作,然后进行预验证
- 首先检查您的表单是否有额外的元素,如果有,请再次添加它们
- 用发布的值填充添加元素
- 证实
public function saveAction()
{
function findFields($field) {
// return field names that include 'extraElement_'
if (strpos($field, 'extraElement_') !== false) {
return $field;
}
}
//set all stuff you need especially the form
if($this->getRequest()->isPost()) {
$postValues = $this->getRequest()->getPost();
//step 1
$extraFields = array_filter(array_keys(current($postValues)), 'findFields');
//add the element before validation
if(count($extraFields) !== 0) {
foreach(extraFields as $extraField) {
$this->addFields($postValues[$extraField]); <-- step 2 add the field(s)
}
}
//step 3 validate
if($this->_form->isValid($postValues)) {
//do post validation stuff
} else {
//show errors
}
}
}
于 2012-06-14T07:38:52.820 回答