http://www.sufeinet.com/plugin.php?id=keke_group

苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 4228|回复: 1

[Jquery] jQuery-Ajax执行完后再执行其他操作

[复制链接]
发表于 2021-7-14 14:46:16 | 显示全部楼层 |阅读模式
       通常使用Ajax的时候,往往都是因为执行先后的问题所烦恼,今天就说下Ajax执行完后在执行其他操作的方法。

       1.运用Ajax的 async 属性设置为 false,将 ajax 同步执行。
        
[JavaScript] 纯文本查看 复制代码
// 声明一个表示状态的全局变量 status
var status = false;
// ajax
$.ajax({
    url:"/checkUsername",
    type:"post",
    // ajax 同步执行
    async:false,
    success:function(){
        status = true;  
	}  
});

// 根据 status 的状态 进行后续操作
function(){
  if(status){
    // 后续操作
	}  
}

     这种情况下有时表现形式不太友好。
      2.利用 jquery 的 when().done 函数 等待 ajax 执行结束之后再进行后续操作。
      
[JavaScript] 纯文本查看 复制代码
// 声明一个表示状态的全局变量 status
var status = false;
// ajax
myajax = $.ajax({
    url:"/checkUsername",
    type:"post",
    success:function(){
        status = true;  
}  
});

// 根据 status 的状态 进行后续操作
function(){
  // myajax 请求完毕时执行
  $.when(myajax).done(function(){
      if(status){
        // 后续操作
      }  
    }) ;
}
   此时的 status 是在 ajax 执行完成后被重新赋值后的 status ,值为 true。

    推荐使用第二种方法。希望可以帮助到大家!


1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
发表于 2021-7-15 14:12:28 | 显示全部楼层
支持下
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-12-22 19:47

© 2014-2021

快速回复 返回顶部 返回列表