laravel ajax状态修改

AJAX相信大家都不陌生,有很多不同的Javascript Frameworks可以用来快速实现AJAX功能。那么今天我们一起来看一下如何在使用了PHP Frameworks的网站中使用AJAX来刷新页面的一小部分。

这里我使用的是jQuery + Laravel(当然如果使用了其他框架,基本的概念也是不变的)。如图,假设我们制作了一个页面来管理客户的茶叶消耗: 

展示:

 <td>
                            @if($arr['fang_status'] == 0)
                                <span fang_status="{{$arr['fang_status']}}" onclick="changeStatus(this,{{$arr['id']}})"
                                      class="label label-defalut radius">未出租</span>
                            @else
                                <span fang_status="{{$arr['fang_status']}}" onclick="changeStatus(this,{{$arr['id']}})"
                                      class="label label-success radius">已出租</span>
                            @endif
                        </td>

js代码修改

 function changeStatus(obj, fang_id) {
            var url = "{{url('admin/fang/changestatus')}}";
            //获取状态
            let fang_status = $(obj).attr('fang_status');
            if (fang_status ==0) {
                fang_status =1;
            }else{
                fang_status =0;
            }
            $.get(url, {
                fang_id,fang_status
            }).then(ret => {

                if (fang_status == 0) {
                    $(obj).removeClass('label-success').addClass('label-defalut').html('未租');
                } else {
                    $(obj).removeClass('label-defalut').addClass('label-success').html('已出租');
                }
                $(obj).attr('fang_status',fang_status);
            })

        }

php后台代码

public function changestatus(Request $request)
{
    $fangID = $request->get('fang_id');
    $fangStatus= $request->get('fang_status');
    Fang::where('id','=',$fangID)->update(['fang_status'=>$fangStatus]);

    return ['errorCode'=>0,'msg'=>'修改成功','data'=>''];
}

这样就实现ajax无刷新修改成功了!!!

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Laravel中,你可以使用jQuery来实现AJAX提交表单数据并转跳。首先,在视图文件中添加一个表单,如下所示: ``` <form id="myForm" action="{{ route('submitForm') }}" method="POST"> @csrf <!-- 表单内容 --> <button type="submit" id="submitForm">提交</button> </form> ``` 这里使用了Laravel的路由器来指定表单提交的路由,也就是`submitForm`路由。接下来,你需要编写一个AJAX请求脚本,如下所示: ``` <script> $(document).ready(function(){ $('#submitForm').click(function(e){ e.preventDefault(); $.ajax({ url: "{{ route('submitForm') }}", method: 'POST', data: $('#myForm').serialize(), success: function(response){ window.location.href = "{{ route('redirect') }}"; }, error: function(xhr, status, error){ console.log(error); } }); }); }); </script> ``` 这里使用了jQuery来监听表单提交按钮的点击事件,然后使用AJAX请求将表单数据提交到服务器。在成功响应后,我们可以使用`window.location.href`属性来跳转到另一个页面,如上面代码中的`redirect`路由。 最后,你需要在路由文件中定义这两个路由,如下所示: ``` Route::post('/submitForm', 'FormController@submitForm')->name('submitForm'); Route::get('/redirect', 'FormController@redirect')->name('redirect'); ``` 其中,`submitForm`路由用于处理表单提交请求,`redirect`路由用于处理AJAX成功响应后的跳转请求。 希望这可以帮助你实现在Laravel中使用AJAX提交表单数据并转跳。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值