【手机验证码】+86垂直居中的有趣问题

在做+86 的垂直居中时,发现了一些有趣的问题,分享一下。顺便复习下垂直居中的写法。

具体问题

在输入框的左侧显示的+86 要进行垂直居中,我想着应该挺简单的,flex 布局来个 align-items: center;不就搞定了吗 示例代码如下:

html 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>Document</title>
    <style>
      #app {
        height: 100vh;
        width: 100vw;
        display: flex;
        align-items: center;
        justify-content: center;
      }
      .container {
        width: 240px;
        height: 54px;
        background-color: #eee;
        cursor: pointer;
        color: #485633;
        font-size: 16px;
        font-weight: 500;
        display: flex;
        align-items: center;
        justify-content: center;
      }
    </style>
  </head>
  <body>
    <div id="app">
      <div class="container">
        <div class="plus">+&nbsp;</div>
        <div class="number">86</div>
      </div>
    </div>
  </body>
</html>

同样的代码在 Windows 和 Mac 上显示的结果却不同:

Windows 下的效果如下,可以看到+和 86 都较好的垂直居中了

而 Mac 上的效果如下, 虽然完成了垂直居中,但是+ 和 86 的位置不太好

具体原因不太清楚

解决方案

与其说是解决方案,其实就是按照给的 ui 设计图明确下个两个元素的 height 和 margin,保证其对齐了,也算解决了问题

css 复制代码
.plus {
  height: 34px;
  line-height: 34px;
  margin: 9px 0 11px;
}
.number {
  height: 44px;
  line-height: 44px;
  margin: 5px 0;
}

这样 Mac 上的对齐情况就好了

垂直对齐写法

顺便复习下 css 的垂直居中写法

flex 布局

flex 布局算是最常用的一种布局方式,通过 align-items 控制垂直对齐

css 复制代码
.container {
  display: flex;
  align-items: center;
}

line-height 单行文本

通过设置行高等于容器高度,仅适用于单行文本或行内元素,上面的解决方案也使用了

css 复制代码
.container {
  line-height: 34px;
  height: 34px;
  text-align: center;
}

absolute + transform

适用于未知宽高的元素,通过 translate 调整元素自身宽高的 50%,实现精准居中

css 复制代码
.parent {
  position: relative;
  height: 200px;
}
.child {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

grid 布局 ​

通过 place-items 简写属性实现水平和垂直居中,兼容性略低于 Flexbox

css 复制代码
.container {
  display: grid;
  place-items: center;
}

常用的垂直居中方法就这些,有其他的方法欢迎评论区补充

相关推荐
0思必得05 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5165 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino6 小时前
图片、文件的预览
前端·javascript
layman05287 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔7 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李7 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN8 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒8 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库8 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
电商API_180079052478 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫