Zend框架中的确认对话框

时间:2012-09-02 20:09:33

标签: zend-framework dialog confirmation

我正在使用doctrine存储库类构建Zend应用程序来更新,删除数据并将数据插入到数据库中。这些存储库是从控制器操作中调用的,它们完全按照它们应该执行的操作。但是,我想在应用程序中添加一些确认对话框,例如,如果用户想要编辑或删除项目,则必须首先打开“确认编辑”或“删除”对话框,并根据具体情况编辑或删除数据。用户选择的内容。以下是用户点击zend表单提交按钮后更新员工详细信息的一些操作代码示例。

public function updatestaffAction()
{        
    if ($this->getRequest()->isPost()) {
        if ($form->isValid($this->getRequest()->getPost())) {
            $values = $form->getValues();
            $user = $this->entityManager->find('\PTS\Entity\Staff', $values['staff_number']);
            $staffValues = array('staff_number' =>  $values['staff_number'],
                                 'title'        =>  $values['title'],
                                 'first_name'   =>  $values['first_name'],
                                 'last_name'    =>  $values['last_name'],
                                 'telephone'    =>  $values['telephone'],
                                 'cellphone'    =>  $values['cellphone'],
                                 'fax'          =>  $values['fax'],
                                 'email'        =>  $values['email'],
                                 'job_title'    =>  $values['job_title']);

            $this->staffRepository->saveStaff($staffValues);
            $this->entityManager->flush();
        }
    }

人员存储库saveStaff方法只创建一个新的Staff对象,并在工作人员不存在时保留该对象,如果是现有工作人员,则合并新数据,如上面的更新代码所示。

所以我的问题是,如果用户在确认对话框中单击了“是”按钮,我怎样才能将操作更改为仅保存数据。顺便说一句,对话框可以是JQuery或Dojo对话框。

2 个答案:

答案 0 :(得分:2)

创建表单的提交按钮时,请设置js代码:

$submit = new Zend_Form_Element_Submit('delete');

$submit->setAttrib(
'onclick', 
'if (confirm("Are you sure?")) { document.form.submit(); } return false;'
);

或者,如果您想在链接上设置对话框(如果您没有提交表单):

onclick="if (confirm('Are you sure?')) { document.location = this.href; } return false;"

showDialog的代码:

$(function() {
    $( "#dialog:ui-dialog" ).dialog( "destroy" );

    $( "#dialog-confirm" ).dialog({
        resizable: false,
        height:140,
        modal: true,
        buttons: {
            "Are you sure": function() {
                                    // PUT your code for OK button, for eg.
                                    document.form.submit();
                $( this ).dialog( "close" );
            },
            Cancel: function() {
                $( this ).dialog( "close" );
            }
        }
    });
});`

答案 1 :(得分:0)

谢谢,我这样使用了第二个选项:

<a href="<?=$this->url('skill', array('action'=>'delete', 'id' => $skill->getId()))?>" onclick="if (confirm('Are you sure?')) { document.location = this.href; } return false;">Delete</a>

并且它有效:)