JQuery 引发两次$(document.ready)事件
更新时间:2010年01月15日 01:42:34 作者:
ASP.net MVC 做了个工程,不知道为什么Search按就总是执行两次。
页面大概是这样的,一个Partial View,而这个View包含了一小段绑定Search的Javascript,并且用Jquery-ui 的dialog 包含,而且确定不是ASP.net mvc生成HTML的问题,HTML是依照我的想法生成的,后来实在没有办法,把dialog的代码去掉,Search按就正常了。查了一下dialog的代码,发现 是appendTo引发的。
做了实验,代码如下:
代码
<script type="text/javascript">
$(document).ready(function() {
$("#a1").appendTo($("#a2"));
});
</script>
<div id="a1">
<script type="text/javascript">
alert('a1');
</script>
</div>
<div id="a2">
</div>
预计 alert('a1') 应该执行一次的,但是由于使用了appendTo,执行了两次,无论你在 a1 div里面是否使用$(document).ready,都会运行两次javascript,第一次document 加载完成,第二次是调用 appendTo.
首先改为下面这种方式,失败。
代码
<div id="a1">
<script type="text/javascript">
loaded = false;
if (loaded == false) {
alert('a1');
loaded = true;
}
</script>
</div>
再改成下面这种,就可以成功了。
var loaded = false;
$(document).ready(function() {
if (!loaded) {
alert('a1');
loaded = true;
}
});
做了实验,代码如下:
代码
复制代码 代码如下:
<script type="text/javascript">
$(document).ready(function() {
$("#a1").appendTo($("#a2"));
});
</script>
<div id="a1">
<script type="text/javascript">
alert('a1');
</script>
</div>
<div id="a2">
</div>
预计 alert('a1') 应该执行一次的,但是由于使用了appendTo,执行了两次,无论你在 a1 div里面是否使用$(document).ready,都会运行两次javascript,第一次document 加载完成,第二次是调用 appendTo.
首先改为下面这种方式,失败。
代码
复制代码 代码如下:
<div id="a1">
<script type="text/javascript">
loaded = false;
if (loaded == false) {
alert('a1');
loaded = true;
}
</script>
</div>
再改成下面这种,就可以成功了。
复制代码 代码如下:
var loaded = false;
$(document).ready(function() {
if (!loaded) {
alert('a1');
loaded = true;
}
});
您可能感兴趣的文章:
- jquery $(document).ready() 与window.onload的区别
- jQuery之$(document).ready()使用介绍
- JQuery onload、ready概念介绍及使用方法
- jquery中的$(document).ready()使用小结
- Jquery中"$(document).ready(function(){ })"函数的使用详解
- jquery的$(document).ready()和onload的加载顺序
- jquery ready()的几种实现方法小结
- jquery中的$(document).ready()与window.onload的区别
- 用javascript实现jquery的document.ready功能的实现代码
- jQuery 的 ready()的纯js替代方法
相关文章
JQuery 构建客户/服务分离的链接模型中Table分页代码效率初探
JQuery构建客户/服务分离的链接模型中Table分页代码效率初探!2010-01-01
打造个性化的功能强大的Jquery虚拟键盘(VirtualKeyboard)
本文主要讲诉了如何一起一步一步打造个性化的VirtualKeyboard:功能强大的Jquery虚拟键盘,非常的详细,非常实用,有需要的朋友可以参考下2014-10-10
修改jQuery.Autocomplete插件 支持中文输入法 避免TAB、ENTER键失效、导致表单提交
jQuery.Autocomplete 是jquery的流行插件,能够很好的实现输入框的自动完成(autocomplete)、建议提示(input suggest)功能,支持ajax数据加载。2009-10-10


最新评论