如何阻止锚标记向上移动div内容

时间:2010-08-31 15:13:44

标签: jquery html css jquery-ui

我有一个奇怪的问题,锚标签向上移动div,这引起了相当多的麻烦,但由于混合中有很多不同的部分,我不知道是哪一个引起了问题。我正在尝试构建一个使用jQuery UI库中的模式对话框来显示水平手风琴样式菜单的UI。代码的基本格式如下:

<div id="identifier" class="profilePanel">
   <ul>
      <li>
         <div class="card">
             <div class="header"><h1>Header</h1></div>
             <div class="content">
                 <!--Content goes here! -->
             </div>
         </div>
      </li>
      <li>
        ...
      </li>
   </ul>
</div>

每张卡的设计都是为了在您点击它时,当前展开的卡片的宽度会缩小,新卡片的宽度也会增加。这都是在jQuery辅助的javascript中完成的。每张卡的附加内容都是通过溢出隐藏的:隐藏在css中,只有缩小时才能看到卡内的标题div。相关的css如下:

ul {
list-style: none;
margin: 0;
padding: 0;
}

div.profilePanel {
    display: none;
}

div.profilePanel li {
    float: left;
}

div.profilePanel li div.card {
    overflow: hidden;
    height: 375px;
    width: 30px;
    background-color: #e0f3fb;
    padding: 0px 2px 2px 0px;
}

div.profilePanel li p {
margin: 0;
padding: 0;
display: block;
margin-left: 35px;
}

div.header {
    border-width: 1px;
    border-style: solid;
    border-color: red;
    display: block;
    float: left;
    width: 30px;
    height: 100%;
    cursor: pointer;
}

div.content {
    padding: 5px 10px;
    height: 365px;
    overflow: auto;
}
div.content li {
    display: block;
    float: none;
}

h1 {
    float: left;
    -webkit-transform: rotate(-90deg);
    -moz-transform: rotate(-90deg);
    direction: rtl;
    font-size: 14pt;
    margin-top: 5px;
    white-space: nowrap;
    width: 30px;
    text-align: center;
    overflow: visible;
}

现在,如果内容div不包含锚标记(即,我可以使用锚标记并将其重命名为跨度以获得正确的格式,如果不是功能),菜单将按预期显示。每个标题占用整个卡片大小,所有内容都在卡片中正确格式化。但是,如果内容div包含锚标记,则标题和内容div都会在页面上向上移动。使用firebug,我可以说卡片div实际上没有移动,但是标题和内容都有。由于这是在一个模态对话框中,我认为它与此有关,但无论我将它拖到哪里,两个div似乎都会相对于对话框的位置移动。

1 个答案:

答案 0 :(得分:0)

首先,我假设您的HTML中某处有一个带有一个profilePanel类的DIV。

我也假设没有任何CSS规则影响锚的位置,即{margin-top:20px;}

现在我可能会在这里弄错,但我认为你使用的是错误的CSS属性。我认为最好使用display:none而不是overflow。显示:在溢出时没有字面隐藏元素:隐藏只隐藏超出其大小的元素的内容。

但是,如果没有看到JavaScript我就无法告诉你真正的问题是什么。