• ajax中的async


    新年第一篇,2019继续与码作伴。
    async boolean default: true
    by default, all requests are sentasynchronous (e.g. this is set to true by default). if you need synchronousrequests, set this option to false. note that synchronous
    requests may temporarily lock the browser,disabling any actions while the request is active.
    async. 默认是true,即为异步方式,$.ajax执行后,会继续执行ajax后面的脚本,直到服务器端返回数据后,触发$.ajax里的success方法,这时候执行的是两个线程。若要将其设置为false
    ,则所有的请求均为同步请求,在没有返回值之前,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。
    下面查看一个示例:
    var temp;
    $.ajax({
     async: false,
      type : "post",
      url : defaultpostdata.url,
      datatype : 'json',
      success : function(data) {
         temp=data;
      }
    });
    alert(temp);
    这个ajax请求为同步请求,在没有返回值之前,alert(temp)是不会执行的。
    如果async设置为:true,则不会等待ajax请求返回的结果,会直接执行ajax后面的语句。
    不过上面设置同步请求的方法,有网友曾经反馈将async设成false后, 原意是想返回数据了再执行$.ajax后面的脚本, 没想到这个地方却导致了在火狐浏览器下出现闪屏(firefox 11.0),滚
    动条下拉到底部触发ajax的情况。最后只能将async:false注释掉,也就是async为ture的情况下,成功解决了火狐浏览器滚动条下拉到底部触发ajax出现闪屏的问题。

  • 相关阅读:
    信号处理引发的cpu高
    两个混淆的用户锁定
    一段获取权限的脚本
    AF_INET 和PF_INET区别;AF_LOCAL PF_LOCAL 区别.
    一个三目运算符问题
    nginx cpu高排查
    mmap 测试的一些坑
    哈希——布隆过滤器 查黑名单(大数据 100亿数据)
    哈希——设计RandomPool结构
    哈希
  • 原文地址:https://www.cnblogs.com/zshno1/p/10282509.html
Copyright © 2020-2023  润新知