JS中事件的执行顺序和AJAX的异步

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS中事件的执行顺序和AJAX的异步相关的知识,希望对你有一定的参考价值。

     之前了解过异步和同步,知道同步是顺序执行,异步是同时执行,但是没有遇到过这种情况,不是很理解,这两天做项目突然遇到了,对这有了一个初步的认识。废话不多说,直接上要求。

 

1.项目要求:外部调用xml文件,然后JS动态生成下拉菜单,使多个文件同时使用此菜单,方便维护。

技术分享

        如图,下面白色为以前的菜单,但是多个地图都需要写同样的菜单比较麻烦,也不好修改,所以做一个xml文件,存储菜单内容,然后多个地图调用,容易修改,蓝色部分菜单。

2.项目代码:此处我使用的Jquery

addMenu(){
       $.ajax({
               url:...,
               type:‘get‘,
               ...
     })
}
$(‘document).ready(function(){
     addMenu();          //添加动态菜单
     loadView();          //添加地图元素
})


//博客仅做简单示范,诸位需要练习,可以私下填充代码

3.出现问题:(1)并且蓝色菜单总是在地图加载之后,才加载出来。

                  因为AJAX是异步的,所以即使将添加下拉菜单函数写在加载地图之前,但是他总是在地图之后显示,即使添加回调函数也没有用(本人亲测)。

                (2)菜单加载出来之后,下拉菜单中添加的事件不能生效。

                  下拉菜单的事件写在加载地图的函数中,但是添加id动态写在ajax中。由于先加载地图函数,后添加id,所以该事件没有绑定到指定的内容上,因此没执行。

                  同时在原生JS中,此情况会报错,因为没有找到指定的DOM,但是JQ中不会报错。

4.解决方法:

     

addMenu(){
       $.ajax({
               url:...,
               type:‘get‘,
               async:false,
               ...
     })
}
$(‘document).ready(function(){
     addMenu();          //添加动态菜单
     loadView();          //添加地图元素
})


//博客仅做简单示范,诸位需要练习,可以私下填充代码

将AJAX中的异步执行关闭掉(默认是开启的),要求先执行AJAX后,事件添加成功。

 

由于本人工作经验尚浅,难免有说的不周全的地方,还请见谅,如果各位有什么指教,欢迎在下方留言,希望一同共勉。

以上是关于JS中事件的执行顺序和AJAX的异步的主要内容,如果未能解决你的问题,请参考以下文章

NodeJS中的异步I/O事件驱动

js找到控件后再下一步操作

如何确保JavaScript的执行顺序

JavaScript异步机制

js定时器 settimeout和其他代码是同步执行还是异步执行

Js执行机制,同步任务异步任务