• 让同一行元素垂直方向对齐的几种方法


    方法1.  Flex弹性布局:

    1. .container { // 父级容器
    2. display: flex;
    3. align-items: center; /* 垂直居中对齐 */
    4. }

    这种方法的优点是简单快捷,缺点是不适合有动画的场景。因为flex的自动内容填充,会破坏动画效果需要的绝对定位。

    方法2. 绝对定位(不推荐)

    1. .parent { // 父级容器
    2. position: relative;
    3. height: ${heisht}px; /* 父元素的高度 */
    4. }
    5. .child { //需要垂直对齐的子元素
    6. position: absolute;
    7. top: 50%;
    8. transform: translateY(-50%);
    9. }

    这个方法有个致命的缺点: 采用绝对定位以后,元素脱离了文档流,也就不会占据原有的位置

    所以,行内的每一个元素的定位参照点都是父级元素的左上角原点,这样带来的后果就是:

    每一个元素都需要手动计算从父级元素最左边开始的margin-left, 否则元素就会都堆叠在最左边的位置,这样就很繁琐,而且也失去了float: left自动占位的优势。

    方法3: 对子元素使用 transform: translateY(+xx%); (xx表示移动的比例)

     这种方法不会影响动画效果,也不需要绝对定位,唯一就是需要调整translateY的偏移值。

    1. #nav .logo {
    2. /* 注意: div必须设置宽高,否则背景色设置不会生效! */
    3. width: 56px;
    4. height: 56px;
    5. background-color: #ff6700;
    6. border-radius: 5px;
    7. transform: translateY(+40%);
    8. /* overflow: hidden是隐藏动画图标的关键 */
    9. overflow: hidden;
    10. }

    方法4: 对于全部是行内元素的情况,可以使用line-height= height,来使得文字垂直居中

    1. . element {
    2. /* 因为line-height会让内容自动撑开元素高度,
    3. 当height和line-height相等时,文字就能垂直居中 */
    4. height: 100px;
    5. line-height: 100px;
    6. }

    因为line-height会让内容自动撑开元素高度,
    所以当height和line-height相等时,文字就能垂直居中

    方法5. 对img标签使用vertical-align: middle使img图片和相邻文字垂直方向对齐

    1. // html结构:
    2. <a :href="#">
    3. <img :src="xxxx">
    4. <span>xxx文字内容</span>
    5. </a>
    6. // css代码:
    7. img{
    8. width: xxpx;
    9. height: xxpx;
    10. vertical-align: middle;
    11. }

  • 相关阅读:
    Jprofiler/ VisualVM 定位内存溢出OOM
    怎么压缩视频?最新压缩技巧大分享
    Sentinel-dashboard-X 实现Sentinel高可用及规则数据持久化
    odoo16原码安装后,psycopg2模块出错,应用除了网站其它都安装不了
    谈谈我对服务网格的理解
    页面分配策略(驻留集,工作集,抖动现象)
    【Java牛客刷题】入门篇(04)
    二叉树的创建与遍历
    基于微前端qiankun的多页签缓存方案实践
    Java EE初阶---软件工程环境
  • 原文地址:https://blog.csdn.net/jiaohuizhuang6019/article/details/132845485