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

    jquery ajax怎么改成同步

    WBOYWBOY2022-09-09 16:13:53原创202

    在jquery中,ajax可以将async设置为false使其同步;默认情况下jquery中的ajax为异步请求,即“async:true”,通过设置参数“asycn:false”即可,语法为“$.ajax({async: false})”。

    大前端成长进阶课程:进入学习

    本文操作环境:windows10系统、jquery3.6.1版、Dell G3电脑。

    jquery ajax怎么改成同步

    jquery中的ajax 默认情况下为异步请求,即 async:true,可以通过设置参数 asycn:false 到使其同步

    ajax默认是异步请求;ajax中可以根据async值的不同来判断是否是异步请求,若async的值为false,则表示ajax请求为同步,若async的值为true,则表示ajax请求为异步,而默认情况下async的值是“true”,因此ajax默认是异步请求。

    如果想同步 async设置为false就可以(默认是true)

    var html = $.ajax({
    url: “some.php”,
    async: false
    }).responseText;

    或者在全局设置Ajax属性

    $.ajaxSetup({
    async: false
    });

    再用post,get就是同步的了

    示例如下:

    随机生成一个10位数的整数,与后端数据库做对比,如果后端数据库中有这个随机数,则重新再生成一个,如果没有就return这个数。

    这个需求涉及到前后端交互,所以无法避免需要使用ajax,于是刚开始我编写了这样一段代码。

    //randID是封装的生成随机数的函数
    function userID() {
        let ranid = parseInt(randID(1000000000, 10000000001));
        let data = null;
        $.ajax({
            type: 'post',
            url: './php/findID.php',
            data: 'id=' + ranid,
            success: function(res) {
                res = JSON.parse(res);
                isok = res.length;
                if (isok != 0) {
                    userID();
                } else {               
                   return ranid;
                }
            }
        })
    }
    console.log(userID());

    输出结果:

    14.png

    jquery.ajax的解决方法

    function userID() {
        let ranid = parseInt(randID(1000000000, 10000000001));
        //声明的局部变量
        let data = null;
        $.ajax({
            type: 'post',
            url: './php/findID.php',
            data: 'id=' + ranid,
            //将ajax改为同步操作
            async: false,
            success: function(res) {
                res = JSON.parse(res);
                isok = res.length;
                if (isok != 0) {
                    console.log(ranid);
                    userID();
                } else {
                    data = ranid;
                }
            }
        })
        //返回这个局部变量
        return data;
    }
    console.log(userID());

    输出结果:

    15.png

    相关教程推荐:jQuery视频教程

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

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:jquery
    上一篇:jquery怎么改变input的value属性 下一篇:jquery动画队列是什么意思
    VIP课程(WEB全栈开发)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• jquery中post()方法怎么用• jquery ajax默认是同步还是异步• jquery框架是java的吗• jquery中.trim()方法怎么用• jquery怎么增加子节点到中间位置
    1/1

    PHP中文网