@dch3

Как отправить данные на сервер с помощью fetch()?

Есть две кнопки, при клике пользователя на одну из них, при помощи fetch отправляется значение кнопки, на которую кликнули, на сервер.

js:
let element = document.querySelector('.radio');

    element.addEventListener('click', function(event) {
        let cat = fetch("http://my-site/transaction", {
            method: 'POST',
            body: event.target.value
        })
        .then(response => response.json())
        .then(data => data);
    });


скрипт php:
Route::get('/test', function (Request $request) {

    $data = $request->all();

    foreach ($data as $value) {
        if ($value == 'income') {
            $categories = Category::where('transaction', 'income')
                ->pluck('category')
                ->unique();
        } 
        elseif ($value == 'expenses') {
            $categories = Category::where('transaction', 'expenses')
                ->pluck('category')
                ->unique();
        }
    }
    return (string) $categories;
});


Проблема в том, что при отправке этого запроса значение event.target.value из запроса fetch не приходит на сервер.
Т.е. директива $data = $request->all() скрипта php показывает, что переменная $data пуста
  • Вопрос задан
  • 213 просмотров
Решения вопроса 1
Malmind
@Malmind
Данные отправляются на сервер, дело в том что PHP не понимает данные, которые ему приходят, чтобы это исправить нужно в заголовках указать 'Content-type': 'application/x-www-form-urlencoded', а в тело запроса передать данные формата key=value&key=value&..., тогда их можно будет увидеть в массиве $_REQUEST (соответственно в request laravel тоже).
let element = document.querySelector('.radio');

    element.addEventListener('click', function(event) {
        let cat = fetch("http://my-site/transaction", {
            method: 'POST',
            headers{
                   'Content-type': 'application/x-www-form-urlencoded'
           }
            body: `radio=${event.target.value}`,
            
        })
        .then(response => {response.json())
        .then(data => data);
    });
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
Mi11er
@Mi11er
A human...
Как минимум это
event.target.value
Меняем на это
JSON.stringify({"value":event.target.value})

а так же логируем что у вас есть в value , дабы там не было пусто
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы