首页 > 代码库 > updatePanel导致JS失效的解决办法(转载)
updatePanel导致JS失效的解决办法(转载)
吐槽下,维护别人之前做的项目好蛋疼,整个页面都是用微软的ajax框架。
今天给repeater用JS写一个hover事件
<script type="text/javascript"> $(function(){ $(‘.trhead‘).click(function(){ $(this).next(‘.trcontent‘).find(‘.divcontent‘).slideToggle(‘fast‘); }); $(‘.trhead‘).hover(function(){$(this).css("background",‘rgb(215,215,215)‘);}, function(){$(this).css("background",‘#fff‘);} ); }) </script>
结果 repeater翻到第二页后,效果失效了,也就是JS没了。
这个时候,就在
protected void AspNetPager3_PageChanged(object sender, EventArgs e) { BindData(); //绑定数据后重新注册一下JS事件 ScriptManager.RegisterClientScriptBlock(up1, GetType(), "aa", "aa()", true); }
而这个aa()函数呢,当然啦,就是:
<script type="text/javascript"> function aa() { $(‘.trhead‘).click(function(){ $(this).next(‘.trcontent‘).find(‘.divcontent‘).slideToggle(‘fast‘); }); $(‘.trhead‘).hover(function(){$(this).css("background",‘rgb(215,215,215)‘);}, function(){$(this).css("background",‘#fff‘);} ); } </script>
也就是把onload要执行的JS,放到一个方法aa()中,在分页绑定数据后,重新注册一下即可。
同理,当别的控件回传后,也需要重新注册下即可。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。