いいえ、これは機能しません。
Axiosに渡す必要があるのはRequestConfigオブジェクトであり、このオブジェクトにはdata
#$プロパティとparams
プロパティがあります。 それらを使用して、サーバーにデータを送信します。
このように: axios.delete(URL, {params: {foo: 'bar'}})
delete request
$では、 data
params
を使用する必要があります。ドキュメントを参照してください。
// "data" is the data to be sent as the request body
// Only applicable for request methods 'PUT', 'POST', and 'PATCH'
// When no
transformRequest is set, must be of one of the following types:
// - string, plain object, ArrayBuffer, ArrayBufferView, URLSearchParams
// - Browser only: FormData, File, Blob
// - Node only: Stream
data: {
firstName: 'Fred'
},
@charlesrochati私は混乱しています。 params
は、クエリ文字列パラメータを送信するためのものですが、これは私が行っていることではありません。
上で引用したものについては、 delete
については何も述べていません。
paramsはクエリ文字列パラメータを送信することですが、それは私が行っていることではありません。
axios.delete
を作りたいのなら、それはまさにあなたがしなければならないことです。
axios.delete(URL, {
は使用しません
data: { foo: 'bar' }
//リクエストメソッド「PUT」、「POST」、「PATCH」にのみ適用可能})
削除リクエストには、 axios.delete(URL, {
を使用しますparams: { foo: 'bar' }
})
'PUT'、 'POST'、および 'PATCH'を使用している場合にのみ、リクエスト本文としてデータを送信します。
axios.post
または( axios.put
またはaxios.patch
)と同じようにaxios.delete
を使用していると思います。 axios.delete
を使用する場合、サーバーにid
を送信すると、サーバー自体が、指定されたid
に一致するresource
を検出します。削除されます(または何らかのアクションをトリガーしますが、リクエストはhttp delete
としてマップされます)。
axios.delete(URL, {
を使用するdata: { foo: 'bar' }
})
resource
を送信していますが、これはまったく意味がありません。
以下のリンクを見てください、あなたはよりよく理解するでしょう:
https://www.w3.org/Protocols/rfc2616/rfc2616-sec9.html [セクション9.7]
HTTPDELETEメソッドにはリクエスト本文を含めないでください。 DELETEは、URIで識別されるリソースを削除するようにオリジンサーバーに指示しています。
私の場合、ペイロードも提供します。 ただし、いずれにしても、 data
を使用して機能する場合は、省略形を使用して機能するはずです。
編集:仕様は、ペイロードの受け渡しを禁止/禁止していません。
axios.deleteの省略形はありません:
axios.request(config)
axios.get(url [、config])
axios.delete(url [、config])
axios.head(url [、config])
axios.post(url [、data [、config]])
axios.put(url [、data [、config]])
axios.patch(url [、data [、config]])
@AkiraLaine仕様では、GETのリクエスト本文の送信も禁止されていません。 axiosでは、GETリクエストでもリクエスト本文を送信するために省略表記を使用できるようにする必要がありますか?
予想される動作であるため、この問題をクローズします。
@cggauravサポートされています。
axios.delete('/some/uri', { body: 'my delete body' })
ちなみに、このようにaxios.delete( '/ some / uri'、{params:{id:1}})を使用すると、サーバーではreq.paramsではなくreq.queryにIDが表示されます。 ただそれをそこに投げたかったのです。
@aricsangchatは、axiosとはまったく関係のないExpressを使用している可能性があります。 expressがparams
を指す場合、それはリクエストパスで一致する動的な値について話します。 axiosがparams
を参照する場合、クエリ文字列パラメーターを参照しています。
// Express
router.get('/:foo/:bar', (req, res) => {
res.json({
query: req.query,
params: req.params
})
})
// Axios
axios.get('/some/uri', { params: { id: 1 } })
.then((response) => console.log(response.data))
実行から得られる出力は次のようになります。
{
"query": { "id": 1 },
"params": {
"foo": "some",
"bar": "uri"
}
}
@jcreadyうんそれは私たちのセットアップです。
削除には本文(投稿など)を含めることができないと書かれているのはどこですか? axiosがこのhttps://tools.ietf.org/html/draft-ietf-httpbis-p2-semantics-19#page-23をサポートしていると便利です。
ありがとう
ご参考までに。 DELETEに本文を付けてはいけないというフェアポイント。 ただし、APIが制御不能な場合に、本文を送信しなければならないことがあります。 例えば
https://auth0.com/docs/api/authorization-extension#remove-user-from-roles👎
@duhseekoh
const extension_url = 'mycompany.auth0.com'
const access_token = 'abc123'
const user_id = 12345
const role_id = 67890
axios.delete(`https://${extension_url}/users/${role_id}/roles`, {
headers: {
'Authorization': `Bearer ${access_token}`,
'Content-Type': 'application/json'
},
body: JSON.stringify([
user_id
])
})
@ jcready-確かに、例に感謝します。 axiosを使用するときにbodyをDELETEに渡す必要がある理由を追加したかっただけです。
@duhseekoh多分これは役立つでしょう: https ://github.com/axios/axios/issues/897#issuecomment -343715381
const response = await axios.delete('/api/matches/delete_match', {
data: { matchInfo }
});
data
で動作していますが、バージョン"axios": "^0.17.1"
でparams
では動作していません
@quinnliu data
またはparams
のどちらを使用するかは、バックエンドがリクエストを処理する方法によって異なると思います。
data
を使用すると、 post
の場合と同じように、ペイロードをリクエスト本文内に配置できます。params
を使用することは、ペイロードをurlパラメーターとして扱うことです。 あなたが送る場合のようにaxios.delete(URL, {
params: { foo: 'bar' }
})
URL?foo=bar.
にリクエストを送信するのと同じです
APIのaxiosからの抽象化。 データ内のパラメータ:名前のみ
``
api.delete(
/ projects / $ {idProjectTech} / techs`、{data:{name:data.name}})
最も参考になるコメント
いいえ、これは機能しません。
Axiosに渡す必要があるのはRequestConfigオブジェクトであり、このオブジェクトには
data
#$プロパティとparams
プロパティがあります。 それらを使用して、サーバーにデータを送信します。このように:
axios.delete(URL, {params: {foo: 'bar'}})
delete request
$では、data
params
を使用する必要があります。ドキュメントを参照してください。// "data" is the data to be sent as the request body
// Only applicable for request methods 'PUT', 'POST', and 'PATCH'
// When no
transformRequestis set, must be of one of the following types:
// - string, plain object, ArrayBuffer, ArrayBufferView, URLSearchParams
// - Browser only: FormData, File, Blob
// - Node only: Stream
data: { firstName: 'Fred' },