源码论坛,商业源码下载,尽在锦尚中国商业源码论坛

标题: 给子div设置的margin-top值在父div上生效了该怎么办? [打印本页]

作者: 洪七公    时间: 2022-7-13 14:20
标题: 给子div设置的margin-top值在父div上生效了该怎么办?

1.问题产生: 在写元素垂直水平居中时,有一种方式是设置子元素margin: 具体值 auto,但此时发现给子元素设置的margin-top值作用在了父元素上

  1. <style>
  2.     .box1{
  3.       width: 200px;
  4.       height: 200px;
  5.       background-color: purple;
  6.       margin: 20px;
  7.     }
  8.     .inner{
  9.       width: 100px;
  10.       height: 100px;
  11.       background-color: yellowgreen;
  12.       margin: 50px auto;
  13.     }
  14.   </style>
  15.   <body>
  16.   <div class="box1">
  17.     <div class="inner">222</div>
  18.   </div>
  19.   </body>
复制代码




2.问题产生的原因:由于css外边距合并导致的

3.解决方案:

(1)方案一:设置父元素overflow:hidden

  1. <style>
  2.     .box1{
  3.       width: 200px;
  4.       height: 200px;
  5.       background-color: purple;
  6.       margin: 20px;
  7.       overflow:hidden;
  8.     }
  9.     .inner{
  10.       width: 100px;
  11.       height: 100px;
  12.       background-color: yellowgreen;
  13.       margin: 50px auto;
  14.     }
  15.   </style>
  16.    <body>
  17.   <div class="box1">
  18.     <div class="inner">222</div>
  19.   </div>
  20.   </body>
复制代码




(2)方案二:给父元素设置有效的border(设置border-style 或者border: 1px solid #000均可)

  1. <style>
  2.     .box1{
  3.       width: 200px;
  4.       height: 200px;
  5.       background-color: purple;
  6.       margin: 20px;
  7.       border-style: solid;
  8.     }
  9.     .inner{
  10.       width: 100px;
  11.       height: 100px;
  12.       background-color: yellowgreen;
  13.       margin: 50px auto;
  14.     }
  15.   </style>
  16. </head>
  17. <body>
  18.   <div class="box1">
  19.     <div class="inner">222</div>
  20.   </div>
  21. </body>
复制代码




(3)方案三其实都是通过改变父级元素的display值(可以设为
display: flex;
display: grid;
display: -webkit-box;
display:inline-flex;
display: inline-grid;
)就可以了,子元素设置固定值或者auto均可实现垂直水平居中

  1.   <style>
  2.     .box1{
  3.       width: 200px;
  4.       height: 200px;
  5.       background-color: purple;
  6.       margin: 20px;
  7.       display: flex;
  8.     }
  9.     .inner{
  10.       width: 100px;
  11.       height: 100px;
  12.       background-color: yellowgreen;
  13.       margin: auto;
  14.     }
  15.   </style>
  16. </head>
  17. <body>
  18.   <div class="box1">
  19.     <div class="inner">222</div>
  20.   </div>
  21. </body>
复制代码




(4)方案四是设置父元素的before伪元素,子元素需设置margin:固定值 auto;方可实现垂直水平居中。

  1. <style>
  2.     .box1{
  3.       width: 200px;
  4.       height: 200px;
  5.       background-color: purple;
  6.       margin: 20px;
  7.     }
  8.     .box1::before{
  9.       content: '';
  10.       display: table;
  11.     }
  12.     .inner{
  13.       width: 100px;
  14.       height: 100px;
  15.       background-color: yellowgreen;
  16.       margin: 50px auto;
  17.     }
  18.   </style>
  19. </head>
  20. <body>
  21.   <div class="box1">
  22.     <div class="inner">222</div>
  23.   </div>
  24. </body>
复制代码









欢迎光临 源码论坛,商业源码下载,尽在锦尚中国商业源码论坛 (https://bbs.52jscn.com/) Powered by Discuz! X3.3