JQuery 引发两次$(document.ready事件

     ASP.net MVC 做了个工程,不知道为什么Search按就总是执行两次。

    页面大概是这样的,一个Partial View,而这个View包含了一小段绑定Search的Javascript,并且用Jquery-ui 的dialog 包含,而且确定不是ASP.net mvc生成HTML的问题,HTML是依照我的想法生成的,后来实在没有办法,把dialog的代码去掉,Search按就正常了。查了一下dialog的代码,发现 是appendTo引发的。

    做了实验,代码如下:


代码
 1  < script  type ="text/javascript" >
 2          $(document).ready( function () {
 3              $( " #a1 " ).appendTo($( " #a2 " ));
 4          });
 5  </ script >
 6 
 7  < div  id ="a1" >
 8           < script  type ="text/javascript" >            
 9             alert( ' a1 ' );           
10           </ script >
11  </ div >
12 
13  < div  id ="a2" >
14  </ div >

 

    预计 alert('a1') 应该执行一次的,但是由于使用了appendTo,执行了两次,无论你在 a1 div里面是否使用$(document).ready,都会运行两次javascript,第一次document 加载完成,第二次是调用 appendTo.

 

首先改为下面这种方式,失败。

代码
1  < div  id ="a1" >
2     < script  type ="text/javascript" >
3          loaded  =   false ;
4           if  (loaded  ==   false ) {
5              alert( ' a1 ' );
6              loaded  =   true ;
7          }   
8           </ script >
9  </ div >

 

  再改成下面这种,就可以成功了。

var loaded = false;
$(document).ready(function() {
     if (!loaded) {
      alert('a1');
      loaded = true;
    }
});
            

 

 

你可能感兴趣的:(document)