繁体   English   中英

laravel ajax发布问题

[英]laravel ajax post issue

我整个周末都在工作,无法正常工作。 我可以使用get而不是post使其工作。 我正在使用Laravel 4和jquery。

我的JS看起来像这样:

$('.status').on('click', function(){
var $modal = $('#ajax-modal');
var id = $(this).attr("id");
setTimeout(function(){
 $modal.load('../status/'+id, '', function(){
 $modal.modal();
});
});
});

这样就可以很好地打开引导程序模式并加载状态页面。 在该页面上,我设置了一个带有用户ID的按钮,然后单击该按钮,我调用了另一个JS代码段:

$modal.on('click', '.update', function(){
$modal
    .find('.modal-body')
    .html('<div class="progress progress-striped active"><div class="bar" style="width: 100%;">Processing ...</div></div>'); 
    var PostData = 'UserId='+$(this).attr("id");
    $.ajax({
        type: "POST",
        url: "",
        data:PostData,
        success: function(msg){
            $('.update').prop('disabled', true);
            setTimeout(function(){
            $modal
            .find('.modal-body')
            .html('<div class="alert-show-success"><img src="../../../public/assets/img/icons/accept.png" />This user was successfully de-activated!</div>');}, 1500);    
        },
        error: function(){
        //alert("failure");
        setTimeout(function(){
        $modal
        .find('.modal-body')
        .html('<div class="alert-show-failed"><img src="../../../public/assets/img/icons/failed.fw.png" />There was an error processing this request!</div>');}, 1500);
        }
        }); 

});

模态加载很好,它可以找到状态页,但是控制器中实际上什么也没发生:(我在那儿用硬编码2对其进行了测试。

public function postStatus()
{
    DB::table('users')
    ->where('id', 2)
    ->update(array('activated' => 0));
}

不知道我在想什么。 任何帮助是极大的赞赏。

尝试这样:

首先,使您为URL命名的路由更具动态性:

Route::post('users/status', array('as'='user_status', 'uses'=>'Controllers\UsersController@postStatus');

然后,更改您的jQuery帖子(我认为这是错误的来源)

$("a.delete").click(function () {
    var $id = $(this).attr("id");

    $.post('{{URL::route('user_status')}}',
        {
            id: $id
        }
    );

});

和您的控制器方法:

public function postStatus()
{
    if(Request::ajax()) {
        $thisID = Input::get('id');
        DB::table('users')
                ->where('id', $thisID)
                ->update(array('activated' => 0));
    }
}

没有尝试,但应该可以。

我建议进行@Arda建议的更改,但我相信您的jquery不正确。 您将键设置为唯一,值设置为data

尝试这个:

$("a.delete").click(function () {
    var id = $(this).attr("id");
    $.ajax({
      type: 'post',
      url: "{{URL::route('user_status')}}", 
      data: {'id' : id}
    });

这需要使用刀片模板,但这还是一个很好的做法。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM