БД не обновляется, когда ajax успешно вызвал метод контроллера laravel - PullRequest
0 голосов
/ 03 сентября 2018

Из моего вывода на консоль я вижу, что сообщение об успехе было отображено из метода контроллера, который вызвал ajax, но я понятия не имею, почему значение в db не изменяется в соответствии со значением.

это мой HTML-код

@foreach($system_functions as $function)
    <input type="hidden" id="id" value="{{$function->id}}" />
    @if($function->group_id == 1)
        <tr>
            <td>{!! $function->name !!}</td>
            <td><input class="toggle_status" type="checkbox" @if($function->is_active) checked @endif id="is_active" name="is_active" data-on="启用" data-off="禁用" value="on" data-toggle="toggle"></td>
        </tr>
    @endif
@endforeach

мой ajax в том же файле

@section('script')
<script type="text/javascript">
    $(document).ready(function() {
        $('.toggle_status').change(function (e) {
            e.preventDefault();
            var is_active = 0
            if ($(this).is(':checked')) {
                is_active = 1;
            }
            $.ajax({
                type: 'POST',
                headers: {
                    'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
                },
                url: '/admin/system-functions',
                async: true,
                data: {
                    is_active: is_active,
                    id: {{ $function->id }}
                },
                success: function (data) {
                    $.confirm({
                        title:'edit?',
                        content:'confirm to edit?',
                        buttons:{
                            confirm: {
                                text: 'edit',
                                btnClass: 'btn-danger',
                                action: function () {

                                }
                            },
                            cancel: {
                                text: 'cancel',
                                btnClass: 'btn-default',
                                action: function () {

                                }
                            }
                        }
                    });
                }
            });
        });
    });
</script>
@endsection

это мой метод в контроллере

public function update(Request $request)
{
    $id = Input::get('id');
    $function=SystemFunction::where('id',$id)->first();
    if($request->get('is_active')==='on'){
        $is_active=1;
    } else{
        $is_active=0;
    }
    $function->update([
        'is_active' => $is_active
    ]);        return response()->json(['success' => 'successful']);
}

это мой маршрут

Route::post('/system-functions', 'SystemFunctionController@update');

это мой модальный класс

class SystemFunction extends Model
{
    protected $fillable=['name','group_id','is_active'];

    static function isFunctionActive($function_name){
        $function=SystemFunction::whereName($function_name)->first();
        if(!$function){
            return false;
        }
        return $function->is_active==true;
    }
}

Ответы [ 2 ]

0 голосов
/ 03 сентября 2018

Попробуйте, если БД не обновляется, вы можете отслеживать это с помощью сообщений об ошибках:

 try {
        $id = Input::get('id');
        $is_active = empty(Input::get('is_active')) ? 0 : 1;
        $function = SystemFunction::findOrFail($id)->update(['is_active' => $is_active]);

        if ($function) {
            return response()->json(['success' => 'successful'], 200);
        } 
        $error = ['errors' => ['message' => 'no data']];

        return response()->json($error, 204);

    } catch (Exceptoin $e) {
        $error = ['errors' => ['message' => $e->getMessage()]];

        return response()->json($error, 200);
    }
0 голосов
/ 03 сентября 2018

попробуйте это:

public function update(Request $request) {
    $id = Input::get('id');
    if($request->get('is_active')==='on'){ 
        $is_active=1; 
    } else {
        $is_active=0;
    }
    $function=SystemFunction::where('id',$id)->update([
        'is_active' => $is_active
    ]);
    return response()->json(['success' => 'successful']); 
}

надеюсь, что это может помочь

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...