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>
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>
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).ready(function() {
if (!loaded) {
alert('a1');
loaded = true;
}
});