أجسام URL-Encoded

افتراضيًا، يسلسل axios كائنات JavaScript إلى JSON. لإرسال البيانات بتنسيق application/x-www-form-urlencoded بدلاً من ذلك، يمكنك استخدام أحد الخيارات التالية.

المتصفح

في المتصفح، يمكنك استخدام API URLSearchParams كالتالي:

const params = new URLSearchParams();
params.append('param1', 'value1');
params.append('param2', 'value2');
axios.post('/foo', params);

لاحظ أن URLSearchParams غير مدعوم من قبل جميع المتصفحات (انظر caniuse.com)، لكن هناك polyfill متاح (تأكد من polyfill البيئة العامة).

بدلاً من ذلك، يمكنك ترميز البيانات باستخدام مكتبة qs:

const qs = require('qs');
axios.post('/foo', qs.stringify({ 'bar': 123 }));

أو بطريقة أخرى (ES6)،

import qs from 'qs';
const data = { 'bar': 123 };
const options = {
  method: 'POST',
  headers: { 'content-type': 'application/x-www-form-urlencoded' },
  data: qs.stringify(data),
  url,
};
axios(options);

Node.js

سلسلة الاستعلام

في node.js، يمكنك استخدام وحدة querystring كالتالي:

const querystring = require('querystring');
axios.post('http://something.com/', querystring.stringify({ foo: 'bar' }));

أو 'URLSearchParams' من 'وحدة url' كالتالي:

const url = require('url');
const params = new url.URLSearchParams({ foo: 'bar' });
axios.post('http://something.com/', params.toString());

يمكنك أيضًا استخدام مكتبة qs.

ملاحظة

مكتبة qs مفضلة إذا كنت بحاجة إلى تحويل كائنات متداخلة إلى سلاسل، حيث أن طريقة querystring لديها مشاكل معروفة مع حالة الاستخدام هذه (https://github.com/nodejs/node-v0.x-archive/issues/1665).

بيانات النموذج

في node.js، يمكنك استخدام مكتبة form-data كالتالي:

const FormData = require('form-data');
 
const form = new FormData();
form.append('my_field', 'my value');
form.append('my_buffer', new Buffer(10));
form.append('my_file', fs.createReadStream('/foo/bar.jpg'));

axios.post('https://example.com', form, { headers: form.getHeaders() })

بدلاً من ذلك، استخدم متدخل:

axios.interceptors.request.use(config => {
  if (config.data instanceof FormData) {
    Object.assign(config.headers, config.data.getHeaders());
  }
  return config;
});