zoukankan      html  css  js  c++  java
  • jQuery Ajax(异步改同步)

    在实际使用中,我们经常会用的Ajax(异步加载,在不刷新整个网页的前提下对网页部分内容进行更新)

    使用时,偶尔会遇上需要从一个接口中得到一个数组和数据对应的id,在另一个接口上再得到数据,最初写法如下:

    $.get(url_1, function (data) {
            var dom = [];
            for (var i = 0; i < data.length; i++) {
                var item = data[i];
                
                //两个url不一致,根据id查找另一个表
                $.get(url_2, function (data) {
                    var item_result = data;
                    dom.push("<div> item_result.id</div>");    
                });
               
            }
            $("#id").empty().append(dom.join(''));      
        });

    但是此时经常会出现数组清空后并没有写入数据的问题,初学时常误以为时接口错误的问题,其实不然

    这是由于$get()等Ajax方法在调用接口时需要时间,导致push还未完成已经发生了append的行为,即此时数组清空,但是dom数组中此时并没有join读取的数据

    故此处需要将循环中的Ajax修改为同步,代码修改如下:

    $.get(url_1, function (data) {
            var dom = [];
            for (var i = 0; i < data.length; i++) {
                var item = data[i];
                
                //在第二次的Ajax前将异步改同步
                $.ajaxSettings.async = false;
    
                //两个url不一致,根据id查找另一个表
                $.get(url_2, function (data) {
                    var item_result = data;
                    dom.push("<div> item_result.id</div>");    
                });
               
                //注意在ajax中的push完成后,将其改回异步
                $.ajaxSettings.async = true;
    
            }
            $("#id").empty().append(dom.join(''));      
        });            
  • 相关阅读:
    bzoj 2744 朋友圈
    bzoj 3674 可持久化并查集加强版
    3.15 模拟赛
    luogu 4720 【模板】扩展卢卡斯
    洛谷 P1447 [NOI2010]能量采集 (莫比乌斯反演)
    洛谷P2522 [HAOI2011]Problem b (莫比乌斯反演+容斥)
    7-12 与零交换 (25 分)
    理想的正方形(单调队列)
    Flowerpot(单调队列)
    生日礼物(单调队列)
  • 原文地址:https://www.cnblogs.com/cyuanwu/p/9782329.html
Copyright © 2011-2022 走看看