【问题标题】:Jumping to top of page when using jQuery hide/show使用 jQuery 隐藏/显示时跳转到页面顶部
【发布时间】: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


【解决方案1】:

如果您正在填充的 div#events-forms 在您单击按钮时没有高度,那么它的高度将变为 0,然后再次展开以适应其内容。这就是触发浏览器跳回的原因,因为没有更多内容要显示。

-如果可能的话,你可以给包含的 div#event-forms 一个固定的大小,所以只有内容在变化,而不是元素的高度。

#events-forms{
border: 1px solid black;
height:400px;

-否则您可能会考虑首先更改包含 div 的高度(使用 javascript/jquery)以适合您要粘贴到其中的数据。

如果您使用以下 css sn-p 可以看到 div 不断增长和扩展,这可能更容易理解为什么您被设置到页面顶部。

#events-forms{
    border: 1px solid black;
}

【讨论】:

  • 我认为这就是问题所在,我查看了边框,你是对的,有一点 div 没有内容,因此没有高度。我暂时通过编写javascript来修复它,当您单击按钮时向下滚动到底部,将其更改为更改div高度的东西。现在它工作正常。感谢您的帮助!
猜你喜欢
  • 1970-01-01
  • 2013-11-02
  • 2013-02-10
  • 1970-01-01
  • 1970-01-01
  • 2021-05-25
  • 2014-05-03
  • 1970-01-01
  • 2015-10-07
相关资源
最近更新 更多