使用ajax获取表单数据

时间:2013-05-15 01:06:58

标签: javascript php jquery ajax cakephp

我正在尝试用ajax做一个简单的表单邮件。 但是,我无法从表单中获取数据。

我的表格:

<?php echo $this->Form->create('Page', array('default' => false)); ?>
<?php echo $this->Form->input('texto', array('label' => FALSE, 'type' => 'textarea)); ?>
<?php echo $this->Form->submit('Enviar', array('id' => 'enviar'));
        echo $this->Form->end();

我的阿贾克斯:

$(document).ready(function() {

$('#enviar').click(function(){
$.ajax({
  type: 'post',
  complete: function(r){
    $('div.teste').html('<h4> Enviado!</h4>');
  }
  })
 })
});

控制器:

    if($this->request->is('ajax')) {
    debug($this->request->data);

App::uses('CakeEmail', 'Network/Email');
$Email = new CakeEmail('gmail');
$Email->to('xxxx@gmail.com');
$Email->subject('Nova Mensagem - Site Althi');
$Email->send($mensagem);

            }

}

我的控制器发送电子邮件。 电子邮件已发送sucefull,但this->request->data的数据是一个空白数组。 我认为问题是从ajax传递的数据。 可以帮帮我吗?

2 个答案:

答案 0 :(得分:0)

您必须在ajax函数调用中设置data值。

$.ajax(
    thecontrollerurl,
    {data: $("#theformid").serialize()}
);

此处有更多信息:http://api.jquery.com/jQuery.ajax/

答案 1 :(得分:-1)

$data = $this->Js->get('#YourformORelementID')->serializeForm(array('isForm' => true, 'inline' => true));

然后

$this->Js->get('#enviar');
$this->Js->event('click', 
$this->Js->request(
    array('controller' => 'someController', 'action' => 'someAction'),
    array('async' => true, 'data' => $data, 'update' => 'div.teste')
));