手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >JQuery 引发两次$(document.ready)事件
JQuery 引发两次$(document.ready)事件
摘要:页面大概是这样的,一个PartialView,而这个View包含了一小段绑定Search的Javascript,并且用Jquery-ui的d...

页面大概是这样的,一个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;

}

});

【JQuery 引发两次$(document.ready)事件】相关文章:

JavaScript Base64编码和解码,实现URL参数传递。

JavaScript中的bold()方法使用详解

一端时间轮换的广告

window.onload与$(document).ready()的区别分析

document.getElementById的一些细节

jQuery实现页面内锚点平滑跳转特效的方法总结

jQuery替换textarea中换行的方法

jQuery获取页面元素绝对与相对位置的方法

JQuery自动触发事件的方法

jquery实现点击label的同时触发文本框点击事件的方法

精品推荐
分类导航