Я пытаюсь отправить запрос GET как второй параметр, но он не работает, пока работает как url.

Это работает, $ _GET ['naam'] возвращает тест:

export function saveScore(naam, score) {
  return function (dispatch) { 
    axios.get('http://****.nl/****/gebruikerOpslaan.php?naam=test')
      .then((response) => {
        dispatch({type: "SAVE_SCORE_SUCCESS", payload: response.data})
      })
      .catch((err) => {
        dispatch({type: "SAVE_SCORE_FAILURE", payload: err})
      })
  }
};

Но когда я пробую это, в $ _ GET ничего нет вообще:

export function saveScore(naam, score) {
  return function (dispatch) { 
    axios.get('http://****.nl/****/gebruikerOpslaan.php',
    {
        password: 'pass',
        naam: naam,
        score: score
    })
      .then((response) => {
        dispatch({type: "SAVE_SCORE_SUCCESS", payload: response.data})
      })
      .catch((err) => {
        dispatch({type: "SAVE_SCORE_FAILURE", payload: err})
      })
  }
};

Почему я не могу этого сделать? В документации четко сказано, что это возможно. С $ _ POST тоже не работает.

Ответы (4)

axios.get принимает конфигурацию запроса как второй параметр (не параметры строки запроса).

Вы можете использовать опцию конфигурации params, чтобы установить следующие параметры строки запроса:

axios.get('/api', {
  params: {
    foo: 'bar'
  }
});

Для меня я пытался отправить параметры, используя axios.post.

При переключении и клиента, и сервера на axios.get, req.query.foo работал как шарм

У меня это отлично работает. Когда это пост-запрос, вложенный объект данных не нужен, но в запросах на получение, чтобы отправить данные, он вам нужен.

axios.get('/api', {
    data: {
        foo: 'bar'
    }
}

На клиенте:

  axios.get('/api', {
      params: {
        foo: 'bar'
      }
    });

На сервере:

function get(req, res, next) {

  let param = req.query.foo
   .....
}

2022 WebDevInsider