码迷,mamicode.com
首页 > Web开发 > 详细

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

时间:2017-05-23 12:15:01      阅读:211      评论:0      收藏:0      [点我收藏+]

标签:syn   代码   没有   了解   人工   http   highlight   下拉菜单   get   

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

 

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的异步

标签:syn   代码   没有   了解   人工   http   highlight   下拉菜单   get   

原文地址:http://www.cnblogs.com/xiaoyamemeda/p/6893359.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!