1

我使用jquery动态创建一个文本框(基于用户选择)..有没有办法从zend表单为该文本框提供验证..?

4

1 回答 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 在表单中获得一个新元素

现在,当您提交时,您必须再次执行此操作,然后进行预验证

  1. 首先检查您的表单是否有额外的元素,如果有,请再次添加它们
  2. 用发布的值填充添加元素
  3. 证实
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 回答