• 技术文章 >web前端 >前端问答

    ajax怎么将异步请求改为同步

    青灯夜游青灯夜游2022-01-17 16:28:32原创2129

    AJAX中根据async值的不同可分为同步和异步,默认情况下async值是true(异步提交);而想将异步改为同步,只需要将async的值设置为false即可。

    本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

    AJAX中根据async的值不同分为同步(async = false)和异步(async = true)

    默认情况下async是true(异步提交)。

    如果想同步 async设置为false就可以。

    示例:

    使用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(''));      
        });

    【相关教程推荐:AJAX视频教程

    以上就是ajax怎么将异步请求改为同步的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:ajax默认是同步还是异步 下一篇:ajax是干什么的
    千万级数据并发解决方案

    相关文章推荐

    • ajax的框架有哪些• ajax函数是什么• ajax单词是什么意思• 使用ajax技术的好处有哪些• form表单和ajax提交的区别是什么
    1/1

    PHP中文网