【发布时间】:2012-10-05 10:15:31
【问题描述】:
我正在尝试根据单击的按钮隐藏/显示一些 div。每次我单击不同的按钮来显示某个 div 时,它都会跳转到页面顶部。如果相关的话,我也在使用 Ruby on Rails。我也尝试过使用 return false ,但这也不起作用。谁有想法?谢谢。
Javascript:
$(document).ready(function(){
$('#new-event-button').click(function(e){
e.preventDefault();
$('#edit-events').hide();
$('#delete-events').hide();
$('#new-event').slideDown();
});
$('#edit-events-button').click(function(e){
e.preventDefault();
$('#new-event').hide();
$('#delete-events').hide();
$('#edit-events').slideDown();
});
$('#delete-events-button').click(function(e){
e.preventDefault();
$('#new-event').hide();
$('#edit-events').hide();
$('#delete-events').slideDown();
});
});
查看代码:
<button id="new-event-button">New Event</button>
<button id="edit-events-button">Edit Events</button>
<button id="delete-events-button">Delete Events</button>
<div id="events-forms">
<div id="new-event">
<%= render :partial => "new_event", :locals => { :event => Event.new(:timeline_id=>@timeline.id) } %>
</div>
<div id="edit-events">
<%= render :partial => "edit_events", :locals => { :events => current_user.events } %>
</div>
<div id="delete-events">
<%= render :partial => "delete_events", :locals => { :events => current_user.events } %>
</div>
</div>
【问题讨论】:
-
您使用的是哪个网络浏览器?
-
slideDown() jquery 动画将您滚动到动画的 div 顶部。您的代码中的一切都是完美的
-
我正在使用 Firefox。我刚刚签入了 Chrome,它也跳到了页面顶部。是否可以为动画指定滚动到哪个 div 以使其不滚动到页面顶部?
-
有没有机会将这些呈现为带有
href="#"的锚标签? -
不,他们没有——他们只是渲染一个表单或一个表格。我认为 retanik 已经找到了解决方案,但还是谢谢。
标签: javascript jquery ruby-on-rails