使用 ajax 多次请求,并将结果集合并(ajax 非异步)

直接上代码吧... 里面有注释

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title></title>
        <script src="js/jquery-3.4.1.js"></script>
    </head>
    <body>
        <script>
            
            (function() {
                var data = {stuId:'4231'};
                var list = [];
                getInfo(function(data,obj){
                    // 第一次查询没有数据或者条数不满足3条数据,进行参数分割
                    if( data ){
                        list.push(data);
                    }else{
                        // 参数分割
                        var stuIds = obj.stuId.split("");
                        // 循环请求获取数据
                        for (var i = 0; i < stuIds.length; i++) {
                            // 参数对象
                            var obj = {stuId: stuIds[i]};
                            //先判断 list 是否的条数 是否满足条件
                            if( list.length >= 2 ){
                                // 中止请求
                                break;
                                //throw Error("满足条件,不再进行请求...");
                            }else{
                                getInfo(function(data){
                                    if( data ){
                                        list.push(data);
                                    }
                                },obj);
                            }
                        }
                    }
                },data);
                
                console.log(list);
            })();
            
            // 回调函数
            function getInfo(callback,stuId) {
                $.ajax({
                    async:false,// 同步请求
                    type: 'get', //请求方式
                    url: 'http://127.0.0.1:8080/stu/findById', //请求服务器地址
                    contentType: "application/json", //设置将要传输内容的编码类型
                    data: stuId, //参数对象
                    success: function(data) { //完成时的事件
                        callback(data,stuId);
                    },
                    error: function(error) { //出现错误时的事件
                        alert("出现异常。");
                    }
                });
            }
        </script>
    </body>
</html>

 

转载于:https://www.cnblogs.com/oukele/p/11576439.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值