2
0
mirror of https://github.com/tenrok/axios.git synced 2026-06-17 19:21:29 +03:00
Files
axios/docs/zh/pages/advanced/html-form-processing.md
T

1.4 KiB
Raw Blame History

HTML 表单提交(浏览器)

你也可以直接从 HTML 表单元素提交数据,无需任何额外的 JavaScript 代码即可提交页面中的表单。

await axios.postForm('https://httpbin.org/post', document.querySelector('#htmlForm'));

FormDataHTMLForm 对象也可以通过显式将 Content-Type 请求头设置为 application/json 来以 JSON 格式发送:

await axios.post('https://httpbin.org/post', document.querySelector('#htmlForm'), {
  headers: {
    'Content-Type': 'application/json',
  },
});

以下是一个有效的、可被上述代码提交的表单示例:

<form id="htmlForm">
  <input type="text" name="foo" value="1" />
  <input type="text" name="deep.prop" value="2" />
  <input type="text" name="deep prop spaced" value="3" />
  <input type="text" name="baz" value="4" />
  <input type="text" name="baz" value="5" />

  <select name="user.age">
    <option value="value1">Value 1</option>
    <option value="value2" selected>Value 2</option>
    <option value="value3">Value 3</option>
  </select>

  <input type="submit" value="Save" />
</form>

上述表单将以如下格式提交:

{
  "foo": "1",
  "deep": {
    "prop": "2",
    "prop spaced": "3"
  },
  "baz": ["4", "5"],
  "user": {
    "age": "value2"
  }
}

::: warning 目前不支持将 Blob/File 以 JSONbase64)格式发送。 :::