并 发 请 求

该博客讨论了如何通过限制并发请求数量来减轻服务器压力。示例代码展示了如何使用Promise处理请求队列,逐个发送请求并在每个请求完成后再发起下一个,从而实现对服务器负载的控制。

如果一次性 就加载100个请求 肯定会造成服务器压力,所以有时候 需要
较少请求,来减轻服务器压力

代码如下

const urls = [];
    for (let i = 0; i < 100; i++) {
        urls.push("http://www.bai.com/" + i);
    }
    function handleRequest(max, urls) {
        return new Promise((resolve) => {
            if (urls.length === 0) {
                resolve([]);
                return;
            }
            const result = [];
            let index = 0;

            async function request() {
                if (index >= urls.length) {
                    return;
                }
                const i = index;
                const url = urls[index];
                index++;
                try {
                    const resp = await fetch(url);
                    result[i] = resp;
                } catch (error) {
                    result[i] = error;
                } finally {
                    // 这个是 相当于 当前的这个通道完成后在继续 调用下一个接口
                    request();
                }
            }
            // 这个是 请求的并发数
            const times = Math.min(max, urls.length);
            for (let i = 0; i < times; i++) {
                request();
            }

            resolve(result);
        });
    }

    const aaa = handleRequest(5, urls);
    console.log(aaa, "aaa");

结果
在这里插入图片描述

在这里插入图片描述

前端使用 AJAX 送 GET 请求跨域,可以通过以下几种方式解决: 1. JSONP(JSON with Padding):JSONP 是一种跨域请求的解决方案,它利用 script 标签的 src 属性不受同源策略限制的特性来实现跨域请求。服务器需要将响应包装在一个函数调用中返回给客户端,在客户端定义一个同名的回调函数来处理响应数据。 ```javascript function handleResponse(data) { // 处理响应数据 } var script = document.createElement('script'); script.src = 'http://example.com/api?callback=handleResponse'; document.body.appendChild(script); ``` 2. CORS(Cross-Origin Resource Sharing):CORS 是一种跨域请求的标准,通过在服务器端设置响应头来允许跨域请求。在客户端送 GET 请求时,浏览器会自动在请求头中添加 Origin 字段,服务器端需要在响应头中添加 Access-Control-Allow-Origin 字段来指定允许跨域访问的域名。 ```javascript var xhr = new XMLHttpRequest(); xhr.open('GET', 'http://example.com/api', true); xhr.onreadystatechange = function() { if (xhr.readyState === 4 && xhr.status === 200) { // 处理响应数据 } }; xhr.send(); ``` 3. 代理服务器:使用代理服务器是一种常见的解决跨域请求的方式。前端送 GET 请求到同源的代理服务器,再由代理服务器转请求到目标服务器,将响应返回给前端。 ```javascript var xhr = new XMLHttpRequest(); xhr.open('GET', '/proxy/api', true); // 同源的代理服务器地址 xhr.onreadystatechange = function() { if (xhr.readyState === 4 && xhr.status === 200) { // 处理响应数据 } }; xhr.send(); ``` 以上是几种常见的解决前端 AJAX 送 GET 请求跨域的方式,根据实际情况选择合适的解决方案。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值