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

在ASP.NET MVC项目中遇到搜索按钮被重复触发两次的问题,通过排除HTML生成和对话框组件的影响,最终定位到jQuery UI的appendTo方法导致问题出现。文中提供了解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

     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;
    }
});
           
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值