我在updatepanel中放了一个datalist显示图片,并且让图片滚动,点击图片后在其他控件中无刷新显示大图并且更新另外一个datalist。但发现点击图片后滚动效果(js代码)失效,把datalist放updatepanel外滚动效果就一直有效,请问在updatepanel中这么让js代码不失效

解决方案 »

  1.   

    这种效果不用那么麻烦,直接用jquery插件吧http://www.cnblogs.com/denleyfu/archive/2010/08/03/1791215.html
      

  2.   

    fellowcheng,我要的无刷新点击缩略图显示大图并且更新datalist已经实现,现在就是datalist图片滚动在点击后失效,初次加载都正常
      

  3.   

    试试重新绑定updatepanel里的dom元素的js事件
      

  4.   

    控制图片滚动的就是以下代码,怎么重新绑定,能说详细一点吗,谢谢
       <script>
            var speed=20
            var feng=document.getElementById("feng");
            var feng2=document.getElementById("feng2");
            var feng1=document.getElementById("feng1");
            feng2.innerHTML=feng1.innerHTML
                function Marquee()
                    {
                        if(feng2.offsetTop-feng.scrollTop<=0)
                        feng.scrollTop-=feng1.offsetHeight
                        else{
                        feng.scrollTop++
                        }
                        }
                        var MyMar=setInterval(Marquee,speed)
                        feng.onmouseover=function() {clearInterval(MyMar)}
                        feng.onmouseout=function() {MyMar=setInterval(Marquee,speed)
                     }
          </script>
      

  5.   

    代码不要放在head中,直接放到你显示图片的控件下
      

  6.   

    代码已经是放在显示图片的控件下的,第一次打开页面有效,但经过updatepanel更新后就失效
    用ScriptManager注册脚本也无效
      

  7.   

    那是应为使用UpdatePanel刷新一次之后,第二次加载时没有触发Onload事件 啊.. .所以JS就失效了... 我也纠结中哦. 
      

  8.   


    UpdatePanel 刷新时,你的控件事件是否在JS邦定的,如果是的话 就在UpdatePanel 的事件中为这个控件再邦定一次就好啦 
    如:
     this.btn_Save.Attributes.Add("onclick", "return CheckInput()");