在laravel中使用ajax更改数据库状态

rpppsulh  于 2021-08-09  发布在  Java
关注(0)|答案(1)|浏览(239)

我在我的项目中使用了laravel,所以我想在他接受医生的任命时更改病人的状态,这样他就可以有3个satuts,accept,waiting(当病人选择日期和时间时自动进行),not accept,我面临的问题是当我单击active按钮时数据库中没有任何更改。
这是状态控制器:

public function changeStatus(Request $request)
{
    $user = rdv::where('IDP', $request->input('IDP'))->get();

    if (count($user) > 0) {
        if ($user->Etat_de_rdv == en_attente) {
            $user->Etat_de_rdv = Accepté;
        } else {
            $user->Etat_de_rdv = Reservé;
        }

        $user->Etat_de_rdv = $request->input('status');
        $user->save();

        return response()->json(['success' => 'Status change successfully.']);
    }
}

以下是脚本:

<script>

    $('.toggle-class').change(function () {
        var status = $(this).prop('checked') == true ? 'Accepter' : 'Temps charger';
        var id = $(this).data('IDP');
        console.log(id);
        console.log(status);
        $.ajax({
            type: "get",
            headers: {
                'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
            },
            url: 'changeStatus',
            data: {
                Etat_de_rdv: status, //Should be like this
                IDP: id
            },
            success: function (data) {
                console.log(data.success);
            }
        });
    });
</script>

这是医生看到所有任命者的观点;

<h3> Vos patient :</h3>
@foreach($pat as $lo)
    @if ($lo->IDD== $med->ID)
        <div class="admin">
            <div class="info">
                <h3> {{ $lo->Nom_et_prénom  }} </h3>
                <p>{{ $lo->Numéro_de_téléphone }}</p>
                <p>{{ $lo->date}}</p>
                <p>{{ $lo->time }}</p>
                <input data-id="{{$lo->IPD}}" class="toggle-class" type="checkbox" data-onstyle="success"
                       data-offstyle="danger" data-toggle="toggle" data-on="Accepter"
                       data-off="Temps charger" {{ $lo->Etat_de_rdv ? 'checked' : '' }}>
            </div>
        </div>
    @endif
@endforeach
  • rdv平均值:任命表*idp:患者id
zzoitvuj

zzoitvuj1#

->get(); 返回集合,而不是数组。因此,你应该使用 $user->count() > 0 相反。
编辑: ->get() 返回对象的集合。所以,你不能使用 $user->Etat_de_rdv == en_attente . 有两种方法可以解决这个问题。
如果您确定idp条件总是返回单个项目,那么您最好使用 ->first() 而不是 ->get() 你不需要改变内部的if条件。
如果有多个用户,那么首先将变量重命名为$users,然后像这样循环 $foreach($users as $user) { // your current code... }

相关问题