好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

纯CSS让子元素突破父元素的宽度限制

在写样式中,我们可以经常看到这样的情况

&nbs p;

代码如下

<div style="width: 300px;border: 4px solid  # 000 ;m  arg in: 20px;padding: 2px;">
    父元素
   <div style="border: 1px solid blue;h ei ght: 100px;wh IT e -s pace: nowrap;">
     <span>子元素子元素子元素子元素子元素子元素子元素子元素子元素子元素子元素子元素子元素子元素子元素子元素子元素子元素子元素子元素</span>
   </div>
 </div>

如果你仔细思考过这个现象的话,why? 可能会问子元素不 应该 撑开父元素的 宽 度吗?就想撑开父元素的高度一样。why? 那么如何让这个子元素的父元素撑开这个宽度呢?这里提供两种解决 方案 。

1. dis play : inline-block

布局样式如下

<!DOCTY PE  ht ML >
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta n am e="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie= Edge ">
  <title>Document</title>
</head>
<style>
  #box1 {
    width: 500px;
    height: 200px;
    border: 2px solid blue;
    padding: 10px;
  }

  #box2 {
    white-space: nowrap;
    display: inline-block;
  }

  #box3 {
    width: 300px;
    height: 200px;
    background-color: blueviolet;
    display: inline-block;
    vert ical -align: middle;
  }

  #box4 {
    width: 400px;
    height: 200px;
    background-color: black;
    display: inline-block;
    vertical-align: middle;
  }
</style>

<body>
  <div id="box1">
    <div id="box2">
      <div id="box3"></div>
      <div id="box4"></div>
    </div>
  </div>
</body>

</html>

结果如图,box3和box4撑开了box2的宽度

2. display: inline-flex

布局样式如下

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>
<style>
  #box1 {
    width: 500px;
    height: 200px;
    border: 2px solid blue;
    padding: 10px;
  }

  #box2 {
    white-space: nowrap;
    display: inline-flex;
  }

  #box3 {
    width: 300px;
    height: 200px;
    background-color: blueviolet;
    vertical-align: middle;
  }

  #box4 {
    width: 400px;
    height: 200px;
    background-color: black;
    vertical-align: middle;
  }
</style>

<body>
  <div id="box1">
    <div id="box2">
      <div id="box3"></div>
      <div id="box4"></div>
    </div>
  </div>
</body>

</html>

效果如下图

到此这篇关于纯CSS让子元素 突破 父元素的宽度限制的 文章 就介绍到这了,更多相关CSS子元素突破父元素宽度内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!

总结

以上是 为你收集整理的 纯CSS让子元素突破父元素的宽度限制 全部内容,希望文章能够帮你解决 纯CSS让子元素突破父元素的宽度限制 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于纯CSS让子元素突破父元素的宽度限制的详细内容...

  阅读:20次