zoukankan      html  css  js  c++  java
  • CSS的inline、block与inline-block

    基本知识点

    行内元素一般是内容的容器,而块级元素一般是其他容器的容器,行内元素适合显示具体内容,而块级元素适合做布局。

    块级元素(block):独占一行,对宽高的属性值生效;如果不给宽度,块级元素就默认为浏览器的宽度,即就是100%宽。

    行内元素(inline):可以多个标签存在一行,对宽高属性值不生效,完全靠内容撑开宽高。

    行内块元素(inline-block):结合的行内和块级的优点,既可以设置长宽,可以让padding和margin生效,又可以和其他行内元素并排。

    clipboard.png

    其中img和input为行内块元素

    行内元素与块状元素之间的转换:

    1. float: 当把行内元素设置完float:left/right后,该行内元素的display属性会被赋予block值,且拥有浮动特性。行内元素去除了之间的莫名空白。
    <head>    
    <meta charset="UTF-8">    
    <title>测试</title>    
    <style type="text/css">        
    p{
        background-color: red;
        height: 500px;
         30%;
        padding: 20px;
        margin: 20px;
        float: left;}        
    div{
        background-color: green;
        height: 50px;
         40%;
        padding: 20px;
        margin: 20px;}       
    span{
        background-color: gray;
        height: 70px;
        padding: 40px;
        margin: 20px;
        float:left;
        200px;}       
    strong{
        background-color: blue;
        height: 70px;
        padding: 40px;
        margin: 20px;}    
    </style>
    <!--<p>块级元素一</p>-->
    <div>块级元素一</div>
    <span>行内元素一</span>
    <strong>行内元素二</strong>
    </body>

    clipboard.png

    如图,当把行内元素一设为左浮动时,就可以为其设置宽度了,说明它已经变成了块级元素。

    2. position: 当为行内元素进行定位时,position:absolute与position:fixed.都会使得原先的行内元素变为块级元素。

    3 .display:

    1、块级标签转换为行内标签:display:inline;

    2、行内标签转换为块级标签:display:block;

    3、转换为行内块标签:display:inline-block;

    常用的 display 可能的值:

    clipboard.png

    特性

    1.text-align属性对块级元素起作用,对行内元素不起作用:

    原因是块级标签如果不给宽度,块级元素就默认为浏览器的宽度,即就是100%宽,那么在100%的宽度中居中生效;但是行内元素的宽完全是靠内容撑开,所以宽度就是内容撑开的宽:

    clipboard.png

    所以块级是在盒子中间居中了,但是因为行内元素的宽就是内容宽,没有可居中的空间,所以text-align:center;就没有作用;但是如果给font转换为块级就不一样了:

    clipboard.png

    2.块级元素独自占一行且宽度会占满父元素宽度,行内元素不会独占一行,相邻行内元素可以排在同一行。

    clipboard.png

    3.块级元素可以设置weith和height,行内元素设置width和height无效,而且块级元素即使设置宽度也还是独占一行。注意但块级元素当没有明确指定 width 和 height 值时,块级元素尺寸由内容确定,当指定了 width 和 height 的值时,内容超出块级元素的尺寸就会溢出,这时块级元素要呈现什么行为要看其 overflow 的值(visible,hidden,overflow,scroll)

    4.块级元素可以设置margin和padding属性,行内元素水平方向的margin和padding如margin-left、padding-right可以产生边距效果,但是竖直方向的margin-top、margin-bottom不起作用。

    5.行内元素的padding-top和padding-bottom会起作用,不过就像脱离了标准流一样(即padding-left和padding-right的层级比其他元素高),并不会占据位置,并且还把其他元素给盖住了。但是,假如inline的元素没有内容,“padding-top、padding-bottom"将不起作用。如果想要起作用,只需要给padding-left或者padding-right设置一个值,或者当inline的元素有内容时就会起作用。

    <style type="text/css">        
    div{
         background-color: green;
         height: 50px;
          40%;;
         padding: 20px;
         margin: 20px;}        
    span{
         background-color: 
         gray;height: 70px;
         padding: 40px;margin: 20px;}        
         strong{background-color: blue;
         height: 70px;
         padding: 40px;
         margin: 20px;
         float: left;
         }    
    </style>
    <div>块级元素一</div>
    <span>行内元素一</span>
    <strong>行内元素二</strong>

    clipboard.png

    clipboard.png

    如图所示,当我们改变padding值时,效果是背景向四个方向扩展,padding-top和padding-bottom是增大的,但是对于块状元素一是没有影响的(在竖直方向上),不然行内元素一也不会挤入块状元素了。


    下面的实例可以看到如果inline的元素没有内容,“padding-top、padding-bottom"将不起作用

    <style>
         body,div{
             margin: 0;
             padding:0;
         }
            .item1{
                height:100px;
                background-color: red;
            }
            .item2{
                display: inline;
                padding-top: 50px;
                padding-bottom: 50px;
                background-color: pink;
            }
        </style>
     <div class="item1"></div>
    <div class="item2"></div>

    clipboard.png


    如果想让padding-top或者padding-bottom起作用,只需要给padding-left或者padding-right设置一个值,或者当inline的元素有内容时就会起作用。

    <style>
         body,div{
             margin: 0;
             padding:0;
         }
            .item1{
                height:100px;
                background-color: red;
            }
            .item2{
                display: inline;
                padding-top: 50px;
                padding-bottom: 50px;
                padding-left: 50px;
                background-color: pink;
            }
        </style>
      <div class="item1"></div>
    <div class="item2"></div>

    clipboard.png

    6.当inline-block碰到同类(inline,inline-block)时,谁的上下margin、paddin或line-height大,就听谁的。除非它是inline,因为inline的margin是不起作用的。且inline的padding是不占空间的。

    <style>
         body,div{
             margin: 0;
             padding:0;
         }
            .item1{
                display: inline-block;
                 100px;
                height:100px;
                margin-top: 20px;
                background-color: red;
            }
            .item2{
                margin-top: 100px;
                display: inline-block;
                background-color: pink;
            }
        </style>
      <div class="item1">item1</div>
    <div class="item2">item2</div>

    clipboard.png


    <style>
         body,div{
             margin: 0;
             padding:0;
         }
            .item1{
                display: inline-block;
                 100px;
                height:100px;
                line-height: 100px;
                background-color: red;
            }
            .item2{
                display: inline-block;
                background-color: pink;
            }
        </style>
      <div class="item1">item1</div>
    <div class="item2">item2</div>

    clipboard.png

    如图所示,inline-block碰到同类时,行高也会一起使用。其他的padding-top和margin-top甚至都会一起使用

    7.inline和inline-block会引起间距的空格

    <style>
         body,div{
             margin: 0;
             padding:0;
         }
            div{
                display: inline;
                background-color: #61dafb;
            }
        </style>
      <div class="item1">item1</div>
    <div class="item2">item2</div>

    clipboard.png

    可以看到两个div之间会有几个像素的间距,这个间距是有换行或回车导致的。有以下解决方法

    (1)将空格直接删除,放到一行

     <div class="item1">item1</div><div class="item2">item2</div>

    (2)在空格代码中加入注释

    <div class="item1">item1</div><!--
    --><div class="item2">item2</div>

    (3)设置margin-left为负值,但是每个浏览器的间距不一样,所以基本不用这种方法

    .item2{
      margin-left:-8px;
      display:inline;
      background-color:pink;
    }

    (4)给父元素增加“font-size:0px"

    <style>
         body,div{
             margin: 0;
             padding:0;
         }
          body{
              font-size: 0px;
          }
            .item1{
                display: inline-block;
                100px;
                height:100px;
                font-size: 20px;
                background-color: red;
            }
            .item2{
                display:inline-block;
                font-size: 20px;
                background-color: pink;
            }
        </style>
      <div class="item1">item1</div>
    <div class="item2">item2</div>
    

    clipboard.png

    (5)给父元素加letter-spacing负值,然后通过子元素清除letter-spacing值

    <style>
         body,div{
             margin: 0;
             padding:0;
         }
          body{
              letter-spacing: -8px;
          }
          body *{
              letter-spacing: 0px;
          }
          .item1{
                display: inline-block;
                100px;
                height:100px;
                background-color: red;
            }
          .item2{
                display:inline-block;
                background-color: pink;
            }
        </style>
      <div class="item1">item1</div>
    <div class="ite
    
  • 相关阅读:
    gmap 整理
    记录一次mybatis genertor使用以及mapper扫描遇见的问题
    mysql 记录
    NOIP2018Day1!!!题目出炉!!!
    图论——倍增求LCA
    干货系列——模板 之 图论1
    数学专题1
    动态规划——背包问题1:01背包
    图论——最短路——Dijkstra算法
    数据结构——并查集
  • 原文地址:https://www.cnblogs.com/10manongit/p/12793453.html
Copyright © 2011-2022 走看看