在laravel5

时间:2015-12-13 09:48:20

标签: php jquery ajax laravel

我正在尝试使用jquery ajax提交带有图片上传的表单,但每次我选择一个图像并单击提交按钮提醒($(this).serialize())显示 -

_token = TCWpR3n9Uf2FpKMXi639Dcvzhc7t4fVDWDopjZ8V。

这是我的表格 -

{!! Form::open(['action'=>'ImageController@store', 'name'=>'form1', 'id'=>'formId1', 'files'=>true]) !!}

<div class="form-group">
{!! Form::file('image') !!}                         
</div>
<div class="form-group">
{!! Form::submit('Upload', array( 'class'=>'btn btn-danger', 'name'=>'image_form_submit'  )) !!}                        
</div>
{!! Form::close() !!}

这里是js -

<script src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>

<script type="text/javascript">
    $(document).ready(function() {
        $("form").submit(function(e){ //
           e.preventDefault();


        alert($(this).serialize()); //always alerts the tocken- _token=TCWpR3n9Uf2FpKMXi639Dcvzhc7t4fVDWDopjZ8V 
        $.ajax({

            type:"POST",
            url: $(this).attr('action'),
            data: $(this).serialize(),
            dataType: 'json',
            success: function(data){
                console.log(data);
            },
            error: function(data){

            }
        })
            return false;
        });
    });
</script>

我想获取表单的序列化数据并通过ajax发布到我的控制器。 为什么警报总是显示令牌?

1 个答案:

答案 0 :(得分:1)

如果ajax图像上传&#34; $(this).serialize()&#34;没有工作。

您必须传递(data:formData,),如下所示 -

 $.ajax({
        type:"POST",
        url: $(this).attr('action'),
        data:formData,
        cache:false,
        contentType: false,
        processData: false,
        success: function(data){
            console.log(data);
        },
        error: function(data){

        }
    })