Rumah >hujung hadapan web >tutorial css >CSS居中布局总结

CSS居中布局总结

高洛峰
高洛峰asal
2016-11-23 15:15:421443semak imbas

居中布局

 

demo

1.水平居中

    1>     方案一 inlink-block+text-align

             .child {display:inlink-block;}

             .parent {text-align:center;}

             优点:兼容性好

             缺点:子元素宽高不可设置

    2>     方案二 table+margin

             .child {display:table; margin:0 auto;}

             优点:只需要设置child(自己)

    3>     方案三 absolute+transform

             .parent {position:relative;}

             .child {position:absolute;left:50%;transform:translateX(-50%);}

             优点:子元素不会对其他元素产生影响

             缺点:兼容性问题

    4>     方案四 flex+justify-content

             .parent {display:flex;justify-content:center;}

             优点:只需设置parent节点

             或者设置为

             .parent {display:flex;}

             .child {margin:0 auto;}

             缺点:flex低版本ie不支持

 

2.垂直居中

    1>     方案一 table-cell+vertical-align

             .parent {display:table-cell;vertical-align:middle;}

             优点:只需设置父节点,兼容性好

    2>     方案二 absolute+transform

             .parent {position:relative;}

             .child {position:absolute;top:50%;transform:translateY(-50%);}

             优点:子元素不会对其他元素产生影响

             缺点:兼容性问题

    3>     方案三 flex+align-items

             .parent {display:flex;align-items:center;}

             优点:只需设置父节点

             缺点:兼容性问题

 

3.水平和垂直均居中

     1>     方案一 inline-block+text-align+table-cell+vertical-align

              .parent {text-align:center;display:table-cell;vertical-align:middle;}

              .child {display:inline-block;}

     2>     方案二 absolute+transform

              .parent {position:relative;}

              .child { position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);}

     3>     方案三 flex+justify-content+align-items

              .parent {display:flex;justify-content:center;align-items:center;}

 

 

思路:了解属性值特性,分解问题。


Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:css基本知识框架图Artikel seterusnya:Sass学习