意外的CSS行为

Luk*_*asz 6 html css

我的布局遇到了一些问题我无法解释.

布局HTML

<!DOCTYPE html>

<html>
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>AuctionProject</title>

    <script async type="application/dart" src="auctionproject.dart"></script>
    <script async src="packages/browser/dart.js"></script>

    <link rel="stylesheet" href="auctionproject.css">
  </head>
  <body>    
    <div id="menu_bar">
      <div id="logo"></div>
      <div class="menu_tab" id="123">Tab123</div>
      <div class="menu_tab" id="upcomming">Tab456</div>
    </div>
    <div id="content_box">
      <div id="side_menu">
        <div id="open_menu_shadow"></div>
        <div id="menu_content" class="hidden">
          <div id="account" class="side_label hidden">
            <p class="tiny">You are currently logged in as:</p>
            <p id="current_user">Some User</p>
            <p class="tiny">This is not you?
              <span class="important" id="log_out" role="button" tabindex="0" style="cursor: pointer;">Log Out</span>
            </p>
          </div>
          <div id="login_box" class="side_label">
            <input type="text" name="login" placeholder="Login">
            <input type="text" name="password" placeholder="Password">
            <button type="button">Sign In</button>
            <p class="tiny">Don't have an account? <span class="important" id="register" role="button" tabindex="0" style="cursor: pointer;">Register</span></p>
          </div>
          <hr>
          <div class="side_label">Add Category</div>
          <div class="side_label">Super category 1</div>
          <hr>
          <div class="side_label">Popular #tags:
            <ol id="trendingTags">
              <li><div class="label">#Tag123</div></li>
              <li><div class="label">#Tag456</div></li>
            </ol>
          </div>
        </div>
        <div id="open_menu"><p>&lt &lt &lt &lt &lt &lt &lt &lt &lt &lt</p></div>
      </div>
      <div id="smart_box">

      </div>
      <div id="auction_list">
        <div class="auction">
          <img src=""></img>
          <div class="title">This is a sample title</div>
          <div class="teaser">This is a sample teaser </div>
        </div>
        <div class="auction">
          <img src=""></img>
          <div class="title">This is a sample auction title</div>
          <div class="teaser">This is sample teaser </div>
        </div>        
      </div>
    </div>
  </body>
</html>
Run Code Online (Sandbox Code Playgroud)

布局CSS

body {
  background-color: #FFF;
  font-family: 'Open Sans', sans-serif;
  font-size: 14px;
  font-weight: normal;
  line-height: 1.2em;
  margin: 0px;
  position: absolute;
  height: 100%;
  width: 100%;
}

h1, p {
  color: #333;
}

#menu_bar {
  width: 100%;
  height: 60px;
  padding-bottom: 2px;
  border-bottom: 1px solid #aaa;
  background-color: #F8F8F8;
}

#logo {
  height: 60px;
  width: 200px;
  margin-right: 40px;
  background-color: blue;
  display: inline-block;
}

.menu_tab {
  margin-left: 25px;
  padding: 4px 4px 0px 4px;
  border-left: 1px solid #aaa;
  border-top: 1px solid #aaa;
  border-right: 1px solid #aaa;
  font-size: 1.2em;
  display: inline-block;
  bottom: 0;
  background-color: #ccc;
}

#menu_tab_selected {
  margin-left: 20px;
  padding: 4px 4px 0px 4px;
  border-left: 1px solid #aaa;
  border-top: 1px solid #aaa;
  border-right: 1px solid #aaa;
  font-size: 1.2em;
  display: inline-block;
  bottom: 0;
  background-color: #fff;
}

#content_box {
  boarder: 2px solid red;
  width: 100%;
  height: 100%;
}

#side_menu{
  boarder: 1px solid #aaa;
  height: 100%;
  position: absolute;
  display: inline-block;
  background-color: #F8F8FF;
  float: left;
}

#open_menu {
  border: 1px solid #aaa;
  border-top: 0px solid #aaa;
  display:inline-block;
  position: absolute;
  top: 0;
  right: 0;
  width: 15px;
  height: 100%;
  background-color: #eee;
  z-index: 3;
}

#open_menu_shadow {
  display: inline-block;
  position: absolute;
  top: 0;
  right: 0;
  width: 15px;
  height: 100%;
  box-shadow: -7px 0px 5px #aaa;
  position: absolute;
  z-index: 1;
}

#open_menu p {
  text-align: center;
  vertical-align: bottom;
}

#menu_content {
  width: 200px;
  height: 100%;
  display: inline-block;
  float: right;
}

#menu_content hr {
    border: 0;
    border-bottom: 1px dashed #ccc;
    background: #999;
    margin-top: 20px;
    margin-bottom: 20px;
}

.hidden {
  display: none;
}

.tiny {
  font-size: 0.7em;
}

.important {
  color: red;
}

#login_box input {
  width: 120px;
  margin-bottom: 10px;
}

#current_user {
  margin: 4px;
}

.side_label {
  border: 1px solid #aaa;
  border-top-left-radius: 4px;
  border-bottom-left-radius:4px;
  margin-top: 15px;
  margin-bottom: 15px;
  margin-left: 10px;
  padding: 10px;
  padding-right: 35px;
  box-shadow: -7px 7px 5px #aaa;
  position: relative;
  background-color: #fff;
  z-index: 2;
}

.label {
  margin: 2px;
  padding-left: 5px;
  padding-right: 5px;
  border-radius: 5px;
  font-size: 0.8em;
  font-weight: bold;
  display: inline-block;
  background-color: #ccc;
}

#auction_list {
  margin-left: 200px;
  padding: 20px;
  position: absolute;
  display: inline-block;
  overflow: auto;
  width: calc(100% - 250px);
}

.auction {
  padding: 10px;
  margin-bottom: 10px;
  boarder: 1px solid #aaa;
  border-bottom: 1px solid #aaa;
  border-top: 1px solid #aaa;
}

.auction img {
  width: 60px;
  width: 60px;
}

.auction .title {
  font-size: 1.2em;
  text-decoration: underline;
}

#smart_box {
  margin: 10px;
  width: 300px;
  height: 200px;
  float: right;
  border: 1px solid #aaa;
}
Run Code Online (Sandbox Code Playgroud)

我的第一个问题与display:none属性有关你可以在左边看到的菜单(id ="side_menu")里面有一个id为"menu_content"的div,右边有一个栏(id ="open_menu").要切换菜单,我创建了.hidden包含display:none属性的类.我期望当我将这个类添加到"menu_content"div时它会消失.不幸的是没有任 布局菜单

我认为我的另一个问题与inline-block财产有关.我想主要内容列表id ="auction_list"填满空格,如下所示. 布局内容 这意味着它应该相对于菜单,所以我不必在切换菜单时更改左边距.另外我不知道如何保持帖子(class ="auction")不在右边的div下移动(id ="smart_box")

我会非常感谢任何帮助.

免责声明:请不要承担太多的先验知识.我是一个html新手.

med*_*uz' 1

1)在#side_menu中,你写了borderer而不是border

\n\n
#side_menu {\n  boarder: 1px solid #aaa;\n  height: 100%;\n  position: absolute;\n  display: inline-block;\n  background-color: #F8F8FF;\n  float: left;\n}\n
Run Code Online (Sandbox Code Playgroud)\n\n

2) CSS 有一个概念,它或多或少地赋予 CSS 规则“权重”。\n当你写下:

\n\n
#menu_content {\n  display: inline-block;\n}\n\n.hidden {\n  display: none;\n}\n
Run Code Online (Sandbox Code Playgroud)\n\n

也许您认为class="hidden"会覆盖id="menu_content". 这就是通常应该发生的情况,因为 .hidden在 CSS 文件中的#menu_content之后写入的。但事实并非如此,因为带有#id 的 CSS 规则比 .class 具有更大的权重

\n\n

如果你想让事情顺利进行,你有两个选择:

\n\n
    \n
  • display: none !important在你的.hidden类中。给予!important最高规则优先级,但这不是一个很好的做法。
  • \n
  • 简单地写:

    \n\n

    #menu_content.hidden {\n display: none;\n}

  • \n
\n\n

最后一个选项会增加权重,因为它更具体:您说您将 CSS 规则显示应用于 1)class="hidden"元素 2) 并且该元素包含一个属性id="menu_content"。更多的特异性意味着更多的权重。

\n\n

#id比 更具体.class,比 更具体<element>

\n\n

要了解有关 CSS 权重的更多信息,请参阅MDNCSS-Tricks

\n\n

3)对于你的最后一个问题,这里有一个小建议,也许不完美,但很容易理解。

\n\n

首先编辑 HTML:将您的智能框放在拍卖列表的开头。

\n\n
<div id="auction_list">\n  <div id="smart_box"></div>\n  <div class="auction">(blabla)</div>\n  <div class="auction">(blabla)</div>\n</div>\n
Run Code Online (Sandbox Code Playgroud)\n\n

这不是解决您的问题的正确方法(从语义上讲,我的意思是),但是现在,让我们编辑 CSS\xe2\x80\xa6\nFor #auction_list,删除位置、显示和宽度。

\n\n
#auction_list {\n  margin-left: 200px;\n  padding: 20px;\n  overflow: auto;\n}\n
Run Code Online (Sandbox Code Playgroud)\n\n

对于.auction,只需添加 inline-block 即可。

\n\n
.auction {\n  padding: 10px;\n  margin-bottom: 10px;\n  border-bottom: 1px solid #aaa;\n  border-top: 1px solid #aaa;\n  display: inline-block;\n}\n
Run Code Online (Sandbox Code Playgroud)\n\n

但请注意,元素的宽度.auction很大程度上取决于它们的内容(如果您不指定任何内容,这就是inline-blockwidth的工作原理)。这意味着您可能会在浏览器渲染中遇到由 \xe2\x80\x9cline\xe2\x80\x9d 进行的 2 次拍卖。我认为,这种结构的改进将取决于你将用它做什么+设计选择。

\n\n

该提案背后的想法是:不要触及定位#auction_list,而是更好地处理其中的元素。

\n\n

希望有帮助。:)

\n