首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

ajaxjs 事件执行顺序

有一个需求,滚轮滚动到相应位置时候执行当前动画,这个动画在footer里面,而网页主体通过ajax进行渲染,我在js里面调用ajax渲染数据,然后再获取主体高度,滚动到该高度时候执行动画。...我大致想了两种解决办法,均以失败告终,本地是ajax执行,服务器是js执行。...让获取高度事件时间延时500ms,发现最后获取不到事件了; 将该事件写在ajaxsuccess回调里面,结果是只有打开网页第一次能够成功,然后不管刷新多少次均无效,事件被屏蔽,所以方法二也被废除;...最后我想到了,ajax不就是一种异步方法,我将其改为同步不就行,先让ajax执行完在执行js事件。...当然这样做有弊端,如果接口出问题,ajax渲染失败,那么整个网页js都将执行不了。不过我想真到了数据都渲染不出地方,访问网页就没有意义了,所以最后我采用了这种方法。

2.9K30

JS执行顺序

javascript给人直观感受是,从上往下执行,但实际上却不是这样,先看个例子 1. console.log(test); 2. var test = "你好"; 3. console.log(...因为javascript执行时,在同一个作用域内是先编译再执行 编译时候会编译 function 和 var 这两个关键词定义变量,编译完成后从上往下执行并向变量赋值 所以执行第1行时, var test...已经执行过了,所以test不会报错,而test2就会报错 需要注意是,对 var test 执行编译时,只是先定义了 test 这个变量,并不会把 "你好" 这个值赋给test,而是到第2行时才给test...赋值,这就是为什么第1行执行结果是 undefined 对于上面的例子,可以这样理解 //先编译 var 定义变量 1. var test; //编译完成后,从上到下执行代码 2. console.log...//执行结果是"你好" function test() { console.log("你好"); } 模拟编译执行过程 //找到 function 定义部分进行编译 //以函数名作为变量名,同时用函数赋值

9.2K60
您找到你想要的搜索结果了吗?
是的
没有找到

关于JS执行顺序

背景 众所周知,JS是单线程语言,但它支持异步操作,其核心机制就是JS引擎事件循环。...原理 总的来说,流程图如下: Promise中代码块是立即执行。...更复杂一点 不管我Promise怎么组合,怎么套,由于setTimeout设置是宏任务,所以它始终在这些微任务都执行完成之后才会运行: setTimeout(() => { console.log...所以它们按顺序排列; 2是宏任务,会放到下一次事件循环时执行; 4是微任务,在首次运行时就把它添加到了微任务队列中,所以在下一次事件循环之前就会被执行。...通过这样事件循环,使得单线程JS也可以拥有异步能力,使得如AJAX请求这样费时间操作可以被安排到后面来执行,不影响页面的加载和渲染。

5.6K30

JS如何控制任务执行顺序

Eat supper~ 从这里不难看出,这里主要点是链式调用和流程控制 链式调用很简单,核心点就是函数执行完后 返回 this,栗子: class EatMan { eat(food) {...eat ${food} ~`); return this; } } new EatMan().eat('apple').eat('pear') 这样就实现链式调用了,下面上主菜 - 控制任务执行顺序...这里参考某些中间件实现思路,首先创建一个任务队列,把每个函数放进去,按顺序执行,每个函数执行完成后调用一个 next 函数,执行下一个函数 class EatMan { constructor(...name) { this.name = name; this.tasks = []; this.init(); // 利用 setTimeout 机制 在下一个事件循环才开始执行...Eat dinner~ Eat supper~ 首发自:JS如何控制任务执行顺序 - 小鑫の随笔

3.6K30

jQuery AJAX load()方法中代码执行顺序问题

问题来源于菜鸟教程介绍 jQuery load() 方法时用一个实例: JS: $("button").click(function(){ $("#div1").load("demo_test.txt...但是实际运行后发现和预想不一样: 方法中代码执行顺序问题-1.png) 方法中代码执行顺序问题-2.png) 从结果来看,是先弹出 alert 再改变文本内容。那么,为什么会这样呢?...demo_test.txt",function(responseTxt,statusTxt,xhr){ alert(responseTxt); if(statusTxt=="success"){ 运行: 方法中代码执行顺序问题...xhr){ if(statusTxt=="success"){ debugger; console.log("1"); } 运行: 方法中代码执行顺序问题...方法中代码执行顺序问题-5.png) 虽然文本内容看上去不变——但是实际情况是文本内容已经改变了,也就是 load() 方法已经生效了,只是 alert 阻塞了浏览器将它渲染出来。

1.5K50

详解Ajax请求(四)——多个异步请求执行顺序

首先提出一个问题:点击页面上一个按钮发送两个ajax请求,其中一个请求会不会等待另一个请求执行完毕之后再执行?   ...从异步请求执行原理来看,我们知道当一个异步请求发送时,浏览器不会处于锁死、等待状态,从一个异步请求发送到获取响应结果期间,浏览器还可以进行其它操作。这就意味着多个异步请求执行时并行。   ...= new String[2000]; //这里为了说明ajax2不会等待ajax1执行完之后再执行,让ajax1响应数据量较大。...要解决这个问题也不难,这里提供两种解决方案:   (1)Ajax2()方法执行放到Ajax1()success回调函数最后一行。   ...,或者一个异步请求把所有数据返回,然后按照逻辑顺序进行数据展示,这些就不再本文讨论范围内了。

2.6K30

SQL 执行顺序

了解 SQL 执行顺序非常有价值,它可以让我们写出语法正确 SQL,帮助我们简化编写新查询过程。 本文将在 MySQL 基础上,介绍查询语句执行顺序。...实际上,如果是简单单表查询,即查询语句里面只包含了一张表,它将严格按照定义执行顺序执行查询。对于多表查询,数据库有的时候并没有按此顺序运行查询,因为它们实现了一系列优化使查询运行更快。...这些优化可能会改变实际执行顺序,但它们最终必须返回与以默认执行顺序运行查询结果相同。 按照执行顺序规则,排在后面的子句产生结果不能被前面的子句引用。...可以在 ORDER BY 子句中引用 GROUP BY 子句聚合结果,因为 ORDER BY 子句执行顺序在 GROUP BY 子句之后。...如果按照标准执行顺序执行两个大表 LEFT JOIN 再执行 WHERE 过滤,那整个 JOIN 操作将会占用很大内存。

2.2K31

Js原生Ajax和JqueryAjax

Js原生Ajax和JqueryAjax 一、Ajax概述 1.什么是同步,什么是异步 同步现象:客户端发送请求到服务器端,当服务器返回响应之前,客户端都处于等待 卡死状态 异步现象:客户端发送请求到服务器端...,直到服务器端将数据返回 给Ajax引擎后,会触发你设置事件,从而执行自定义js逻辑代码完成某种页面1 功能。...二、js原生Ajax技术(了解) js原生Ajax其实就是围绕浏览器内内置Ajax引擎对象进行学习,要使用js原 生Ajax完成异步操作,有如下几个步骤: 1)创建Ajax引擎对象 2)...常用json转换工具有如下几种: 1)jsonlib 2)Gson:google 3)fastjson:阿里巴巴 四、JqueryAjax技术(重点) jquery是一个优秀js框架,自然对...js原生ajax进行了封装,封装后ajax操 作方法更简洁,功能更强大,与ajax操作相关jquery方法有如下几种,但开发中 经常使用有三种 1).get(url, [data], [callback

19.6K20

MySQLsql执行顺序

在SQL语句中每个关键字都会按照顺序往下执行,而每一步操作,会生成一个虚拟表,最后产生虚拟表会作为执行最终结果返回。下面的是常用关键字执行顺序: ?...)未匹配行作为外部行添加到虚拟表VT2中,从而产生虚拟表VT3; 4、WHERE:对虚拟表VT3进行WHERE条件过滤,只有符合记录才会被放入到虚拟表VT4; 5、...:对虚拟表VT6进行HAVING条件过滤,只有符合记录才会被插入到虚拟表VT7中; 8、SELECT:执行SELECT操作,选择指定列,插入到虚拟表VT8中; 9...、DISTINCT:对虚拟表VT8中记录进行去重,产生虚拟表VT9; 10、ORDER BY:将虚拟表VT9中记录按照进行排序操作,产生虚拟表VT10; 11、LIMIT...:取出指定行记录,产生虚拟表VT11,并将结果返回。

2.2K20

MySQL语句执行顺序

MySQL语句一共分为11步,如下图所标注那样,最先执行总是 FROM操作,最后执行是LIMIT操作。...其中每一个操作都会产生一张虚拟表,这个虚拟表作为一个处理输入,只是这些虚拟表对用户来说是透明 ,但是只有最后一个虚拟表才会被作为结果返回。...如果没有在语句中指定某一个子句,那么将会跳过相应步骤。 ? 下面我们来具体分析一下查询处理每一个阶段 FORM: 对FROM左边表和右边表计算笛卡尔积。...,那么就会对上一个join连接产生结果VT3和下一个表重复执行步骤1~3这三个步骤,一直到处理完所有的表为 止。...SELECT: 执行select操作,选择指定列,插入到虚拟表VT8中。 DISTINCT: 对VT8中记录进行去重。产生虚拟表VT9.

6.5K100
领券