我的jquery Ajax方法每次都在其他部分

时间:2013-03-05 09:59:22

标签: php jquery serialization phpexcel

我的jQuery方法 -

jQuery("#upload_button").click(function(){
    var exceldata = jQuery("#upload_button").serialize();
    var url = "module/controller/contrlrmethod/exceldata/" + exceldata;
    if( exceldata != "" )
    {
        jQuery.ajax({
            url: url,
            type: 'post',
            success: function(data)
            {
                alert(data);
            }
        })
    }
    else
    {
        alert("I am in else");
    }
});

控制器方法 -

public function contrlrmethodAction()
{
    //Get All Parameter data
    $params = $this->_getAllParams();
    echo "<pre>";print_r($params);die;
}

我通过此按钮upload_button上传Excel表格。但每次进入其他部分时,我是否上传了excel。让我知道我做错了什么。我正在使用PHPExcel库来进一步处理数据,但它总是在其他部分。

2 个答案:

答案 0 :(得分:7)

不确定,但看起来你正在序列化按钮..

var exceldata = jQuery("#upload_button").serialize();
                        --^^^^^^----here

它应该是您的表单ID。

var exceldata = jQuery("#formID").serialize(); 

以及其他一些错误...因为您使用的是ajax帖子..您可以通过data选项发送数据,无需在网址中传递序列化数据。

  var url = "module/controller/contrlrmethod/exceldata/";
 jQuery.ajax({
        url: url,
        type: 'post',
        data: exceldata,  //<--here
        success: function(data)
        {
            alert(data);
        }
    })

注意:如果您尝试使用ajax帖子上传文件..那么就不可能,您必须使用iframe ...或使用其他一些ajax文件上传插件< / p>

答案 1 :(得分:0)

您无法使用AJAX上传文件。您必须在表单上进行旧式POST。

另一方面,如果您想使用ajax发送表单,则需要序列化整个表单,而不仅仅是提交按钮。

var serializedForm = $("form").serialize();
jQuery.ajax({
    url: 'module/controller/contrlrmethod',
        type: 'POST',
        data: serializedForm,
        success: function(data)
        {
            alert(data);
        }
    });

但正如我所说,此代码不上传文件。它只是修复你的表格。