亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

CSS 中溢出的工作不符合預期

CSS 中溢出的工作不符合預期

縹緲止盈 2023-12-19 21:05:56
這是代碼ul {  list-style-type: none;  margin: 0;  padding: 0;  overflow: hidden; /*The problem is here*/  background-color: #333;}li {  float: left;}li a {  display: inline-block;  color: blue;  text-align: center;  padding: 14px 16px;  text-decoration: none;}li a:hover {  background-color: #111;}.active {  background-color: red;}<ul>  <li><a href="#home" class="active">Home</a></li>  <li><a href="#news">News</a></li>  <li><a href="#contact">Contact</a></li>  <li><a href="#about">About</a></li></ul>在 ul 樣式中,正在使用溢出隱藏?,F在,當使用溢出隱藏時,導航欄的背景顏色會變成黑色,就像但是當我刪除 Overflow:hidden 時,背景顏色消失了,就像現在基本上我只是感到困惑,因為溢出:隱藏只是將溢出的東西隱藏在容器中,那么為什么在這里它會出現背景顏色呢?
查看完整描述

3 回答

?
暮色呼如

TA貢獻1853條經驗 獲得超9個贊

我不想知道正確的解決方案。我只是想知道為什么溢出:隱藏的行為是這樣的。

由于您的列表項是浮動的,因此默認情況下它們不會影響其父項的?高度?ul?。列表元素本身的有效高度保持在此處?0,因此您實際上在任何地方都看不到背景顏色。

overflow?設置為默認值以外的任何值auto,作為明確修復。這意味著?li?現在將影響?ul?的高度,現在?ul?實際上具有高度,您還會看到它的背景顏色應用于該高度。

如果您不熟悉該術語,可以了解有關什么是“明確修復”以及實現它的其他方法的更多信息。

查看完整回答
反對 回復 2023-12-19
?
慕后森

TA貢獻1802條經驗 獲得超5個贊

除非將溢出設置為隱藏、滾動或自動,否則任何可能浮動的內容都不會被剪切。該方法的真正目的是,在沒有給元素設置高度和寬度的情況下,當您將溢出設置為隱藏時,它會采用內部元素的高度和寬度:https:// codepen.io/Aypro18/pen/ExVVgYa?editors=1000

  <!DOCTYPE html>

   <html>

    <head>

    <style>

    ul {

      list-style-type: none;

      margin: 0;

      padding: 0;

      overflow: auto; //The problem is here and the olution itself

      background-color: #333;

    }


    li {

      float: left;

    }


    li a {

      display: inline-block;

      color: blue;

      text-align: center;

      padding: 14px 16px;

  text-decoration: none;

}


li a:hover {

  background-color: #111;

}


.active {

  background-color: red;

}

</style>

</head>

<body>


<ul>

  <li><a href="#home" class="active">Home</a></li>

  <li><a href="#news">News</a></li>

  <li><a href="#contact">Contact</a></li>

  <li><a href="#about">About</a></li>

</ul>


</body>

</html>


查看完整回答
反對 回復 2023-12-19
?
冉冉說

TA貢獻1877條經驗 獲得超1個贊

添加 display: flex; 至 UI 樣式?,F在,您可以刪除overflow:hidden。發生這種情況是因為父元素沒有充當子元素的容器(因為它們的浮動屬性)。所以,它不會繼承他們的身高并適應它。因此,display flex 解決了這個問題。



查看完整回答
反對 回復 2023-12-19
  • 3 回答
  • 0 關注
  • 174 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號