javascript网络请求

1.所有现代浏览器都通过 XMLHttpRequest 构造函数原生支持 XHR 对象:

let xhr = new XMLHttpRequest();

2.使用 XHR 对象首先要调用 open()方法。调用 open()不会实际发送请求,只是为发送请求做好准备

// 1.请求方式
// 2.url
// 3.是否异步
xhr.open("get", "example.php", false);

3.要发送定义好的请求,必须像下面这样调用 send()方法:send()方法接收一个参数,是作为请求体发送的数据。如果不需要发送请求体,则必须传 null,因为这个参数在某些浏览器中是必需的。调用 send()之后,请求就会发送到服务器

xhr.send(null);

4.响应数据

  • responseText:作为响应体返回的文本。
  • responseXML:如果响应的内容类型是"text/xml"或"application/xml",那就是包含响应 数据的 XML
    DOM 文档。
  • status:响应的 HTTP 状态。
  • statusText:响应的 HTTP 状态描述。

XHR 对象有一个 readyState 属性,表示当前处在请求/响应过程的哪个阶段。每次 readyState 从一个值变成另一个值,都会触发 readystatechange 事件。这个属性有如下可能的值。

  • 0:未初始化( Uninitialized)。尚未调用 open()方法。
  • 1:已打开( Open)。已调用 open()方法,尚未调用 send()方法。
  • 2:已发送( Sent)。已调用 send()方法,尚未收到响应。
  • 3:接收中( Receiving)。已经收到部分响应。
  • 4:完成( Complete)。已经收到所有响应,可以使用了。
    let xhr = new XMLHttpRequest();
    xhr.onreadystatechange = function() {
        if (xhr.readyState == 4) {
            if ((xhr.status >= 200 && xhr.status < 300) || xhr.status == 304) {
                console.log(xhr.responseText);
            } else {
                alert("Request was unsuccessful: " + xhr.status);
            }
        }
    };
    xhr.open("get", "https://www.dmagic.cn/json/?jsonid=1460", true);
    xhr.send(null);

超时
给 timeout 设置 1000 毫秒意味着,如果请求没有在 1秒钟内返回则会中断。此时则会触发 ontimeout 事件处理程序, readyState 仍然会变成 4,因此也会调用 onreadystatechange 事件处理程序。不过,如果在超时之后访问 status 属性则会发生错误。为做好防护,可以把检查 status 属性的代码封装在 try/catch 语句中

xhr.timeout = 1000; // 设置 1 秒超时
xhr.ontimeout = function() {
    alert("Request did not return in a second.");
};
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
JavaScript可以通过XMLHttpRequest对象或者Fetch API来发起网络请求。使用XMLHttpRequest对象的基本步骤如下:\[1\] 1. 创建一个XMLHttpRequest对象:使用`new XMLHttpRequest()`来创建一个XMLHttpRequest对象。 2. 监听对象状态的变化:使用`addEventListener`方法监听`readystatechange`事件,当状态变化时触发回调函数。 3. 配置网络请求:使用`open`方法配置请求的方式和URL地址。 4. 发送网络请求:使用`send`方法发送网络请求。 使用Fetch API的基本步骤如下:\[2\] 1. 使用`fetch`函数发起网络请求:使用`fetch`函数并传入URL地址作为参数来发起网络请求。 2. 监听对象状态的变化:使用`then`方法来监听网络请求的结果。 3. 处理网络请求的结果:在`then`方法的回调函数中处理网络请求的结果。 此外,如果需要取消网络请求,可以使用`abort`方法来强制取消请求。例如,使用XMLHttpRequest对象时,可以在`abort`事件中监听请求的取消。\[3\] 总结起来,JavaScript可以通过XMLHttpRequest对象或者Fetch API来发起网络请求,并可以使用`abort`方法来取消请求。 #### 引用[.reference_title] - *1* *2* *3* [网络编程-JavaScript中发送网络请求汇总](https://blog.csdn.net/m0_71485750/article/details/125632668)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值