zoukankan      html  css  js  c++  java
  • 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;
        }
    });
                

     

  • 相关阅读:
    ES6 语法详解(Promise对象(重点))
    ES6 语法详解(形参默认值)
    ES6 语法详解(三点运算符)
    ES6 语法详解(箭头函数(重点))
    ES6 语法详解(简化的对象写法)
    ES6 语法详解(模板字符串)
    ES6 语法详解(变量的解构赋值)
    [刷题] 走迷宫
    [bug] A reference cannot be reassigned, so it must be initialized at the member-initialization-list.
    [Qt] LibreCAD 源码分析
  • 原文地址:https://www.cnblogs.com/fantasylu/p/1646775.html
Copyright © 2011-2022 走看看