XMLHttpRequest.send()

待我称王封你为后i 2022-03-08 08:36 293阅读 0赞

XMLHttpRequest.send()方法用于实际发出 HTTP 请求。它的参数是可选的,如果不带参数,就表示 HTTP 请求只有一个 URL,没有数据体,典型例子就是 GET 请求;如果带有参数,就表示除了头信息,还带有包含具体数据的信息体,典型例子就是 POST 请求。

下面是 GET 请求的例子。

  1. var xhr = new XMLHttpRequest();
  2. xhr.open('GET',
  3. 'http://www.example.com/?id=' + encodeURIComponent(id),
  4. true
  5. );
  6. xhr.send(null);

上面代码中,GET请求的参数,作为查询字符串附加在 URL 后面。

下面是发送 POST 请求的例子。

  1. var xhr = new XMLHttpRequest();
  2. var data = 'email='
  3. + encodeURIComponent(email)
  4. + '&password='
  5. + encodeURIComponent(password);
  6. xhr.open('POST', 'http://www.example.com', true);
  7. xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
  8. xhr.send(data);

注意,所有 XMLHttpRequest 的监听事件,都必须在send()方法调用之前设定

send方法的参数就是发送的数据。多种格式的数据,都可以作为它的参数。

  1. void send();
  2. void send(ArrayBufferView data);
  3. void send(Blob data);
  4. void send(Document data);
  5. void send(String data);
  6. void send(FormData data);

如果send()发送 DOM 对象,在发送之前,数据会先被串行化。如果发送二进制数据,最好是发送ArrayBufferView或Blob对象,这使得通过 Ajax 上传文件成为可能。

下面是发送表单数据的例子。FormData对象可以用于构造表单数据。

  1. var formData = new FormData();
  2. formData.append('username', '张三');
  3. formData.append('email', 'zhangsan@example.com');
  4. formData.append('birthDate', 1940);
  5. var xhr = new XMLHttpRequest();
  6. xhr.open('POST', '/register');
  7. xhr.send(formData);

上面代码中,FormData对象构造了表单数据,然后使用send()方法发送。它的效果与发送下面的表单数据是一样的。

  1. <form id='registration' name='registration' action='/register'>
  2. <input type='text' name='username' value='张三'>
  3. <input type='email' name='email' value='zhangsan@example.com'>
  4. <input type='number' name='birthDate' value='1940'>
  5. <input type='submit' onclick='return sendForm(this.form);'>
  6. </form>

下面的例子是使用FormData对象加工表单数据,然后再发送。

  1. function sendForm(form) {
  2. var formData = new FormData(form);
  3. formData.append('csrf', 'e69a18d7db1286040586e6da1950128c');
  4. var xhr = new XMLHttpRequest();
  5. xhr.open('POST', form.action, true);
  6. xhr.onload = function() {
  7. // ...
  8. };
  9. xhr.send(formData);
  10. return false;
  11. }
  12. var form = document.querySelector('#registration');
  13. sendForm(form);

发表评论

表情:
评论列表 (有 0 条评论,293人围观)

还没有评论,来说两句吧...

相关阅读