我有一个奇怪的问题,锚标签向上移动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似乎都会相对于对话框的位置移动。
答案 0 :(得分:0)
首先,我假设您的HTML中某处有一个带有一个profilePanel类的DIV。
我也假设没有任何CSS规则影响锚的位置,即{margin-top:20px;}
现在我可能会在这里弄错,但我认为你使用的是错误的CSS属性。我认为最好使用display:none而不是overflow。显示:在溢出时没有字面隐藏元素:隐藏只隐藏超出其大小的元素的内容。
但是,如果没有看到JavaScript我就无法告诉你真正的问题是什么。