在使用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>
<style>
body {
font-size: 16px;
} .fa {
height: 18.75em;
width: 31.25em;
margin: 0 auto;
display: flex;
flex-direction: column;
} .l1,
.l2 {
flex: 1;
background-color: aqua;
display: flex;
border: 0.25em solid black;
border-right: none;
} .l2 {
border-top: none;
background-color: deeppink;
} .son1,
.son2,
.son3,
.son4,
.son5 {
box-sizing: border-box;
border-right: 0.25em solid black;
flex: 1;
} .son5 {
flex: 2;
}
</style>
</head> <body>
<div class="fa">
<div class="l1">
<div class="son1"></div>
<div class="son2"></div>
<div class="son5"></div>
</div>
<div class="l2">
<div class="son1"></div>
<div class="son2"></div>
<div class="son3"></div>
<div class="son4"></div>
</div> </div> </body> </html>

可以发现我们在分配盒子的时候明明除了.son5 设置为flex:2外, 都是设置了 flex:1 ;按照我们预想的结果应该是对齐的,但是事实上在添加边框之后,边框并不能对齐。

产生这个问题的主要原因如下:

首先我们知道flex :n 是flex:n n 0 的简写,主要的作用是将剩余的空间进行按比例划分。

而我们在指定了边框大小后,边框将会占用固定的大小,那么可分配的剩余大小就会改变。

如上例(计算原理不清楚的同学可以参考CSS 小结笔记之伸缩布局 (flex)):

蓝色区域

共有四个竖边框,大小共为4*0.25*16=16px;

那么剩下可分配区域的大小为:31.25*16-16=484px

所以蓝色区域的三块大小分别是:1*484/4=121px、1*484/4=121px、2*484/2=242px

红色区域

共有五个竖边框,大小共为5*0.25*16=20px;

那么剩下可分配区域的大小为:31.25*16-20=480px

所以红色区域的四块大小都是:1*480/4=120px

因此红色区域和蓝色区域的子盒子大小实际上是不对等的,因此边框出现了偏移。

下面将给出这个问题的解决方法:

1、最基本的方法

  使用伸缩基准值(flex-basis)即flex 值中的百分比+border-box 来实现

  首先把右边框都设置为子盒子的边框,接着给子盒子添加属性 box-sizing: border-box,最后将flex:1 改为 flex:0 0 25%,将flex:2改为 flex:0 0 50%。

  这么做的原理是,将子盒子的盒子计算大小模式改为 border-box ,即分配或计算式,边框和内边距也被视为盒子大小的一部分。

  之后再设置每个盒子的起始长度,这样就可以解决这个问题。

  具体代码如下

<!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>
<style>
body {
font-size: 16px;
} .fa {
height: 18.75em;
width: 31.25em;
margin: 0 auto;
display: flex;
flex-direction: column;
} .l1,
.l2 {
flex: 1;
background-color: aqua;
display: flex;
border: 0.25em solid black;
border-right: none;
} .l2 {
border-top: none;
background-color: deeppink;
} .son1,
.son2,
.son3,
.son4,
.son5 {
box-sizing: border-box;
border-right: 0.25em solid black;
flex: 0 0 25%;
} .son5 {
flex: 0 0 50%;
}
</style>
</head> <body>
<div class="fa">
<div class="l1">
<div class="son1"></div>
<div class="son2"></div>
<div class="son5"></div>
</div>
<div class="l2">
<div class="son1"></div>
<div class="son2"></div>
<div class="son3"></div>
<div class="son4"></div>
</div> </div> </body> </html>

  结果图为

  

  这种方法的优点是简单直观,缺点是不够灵活,而且每个盒子的设置都要计算其所占百分比。

2、将边框画出

  我们知道在不给出边框的时候,是不会出现问题的,而且即使不给出边框,盒子与盒子之间也是有分界线的,因此我们可以自己在盒子的边线上通过定位画出一个边框。

  通过::after伪元素选择器,设置其高度100%,宽度为0.25em,定位靠右。这样只要给需要边框效果的盒子增加这个类,则相当于给盒子增加了右边框。 

        .bd-r {
position: relative;
} .bd-r::after {
content: "";
width: 0.25em;
height: 100%;
position: absolute;
background-color: black;
top:;
right:;
}

  完整代码如下:

<!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>
<style>
body {
font-size: 16px;
} .fa {
height: 18.75em;
width: 31.25em;
margin: 0 auto;
display: flex;
flex-direction: column;
} .l1,
.l2 {
flex: 1;
background-color: aqua;
display: flex;
border: 0.25em solid black;
border-right: none;
} .l2 {
border-top: none;
background-color: deeppink;
} .son1,
.son2,
.son3,
.son4,
.son5 {
flex: 0 0 25%;
} .son5 {
flex: 0 0 50%;
} .bd-r {
position: relative;
} .bd-r::after {
content: "";
width: 0.25em;
height: 100%;
position: absolute;
background-color: black;
top: 0;
right: 0;
}
</style>
</head> <body>
<div class="fa">
<div class="l1">
<div class="son1 bd-r"></div>
<div class="son2 bd-r"></div>
<div class="son5 bd-r"></div>
</div>
<div class="l2">
<div class="son1 bd-r"></div>
<div class="son2 bd-r"></div>
<div class="son3 bd-r"></div>
<div class="son4 bd-r"></div>
</div> </div> </body> </html>

  效果图为

  

  可以发现和方法一显示结果一样。这个方法更加便捷,可重用性更高,而且这种写法可以广泛应用于分割线,边框等。

  

CSS 小结笔记之解决flex布局边框对不齐的更多相关文章

  1. CSS 小结笔记之浮动

    在css中float是一个非常好用的属性,float最基本用法是用来做文字环绕型的样式的. 基本用法:float:left | right 例如 <!DOCTYPE html> <h ...

  2. CSS实例详解:Flex布局

    本文由云+社区发表 本文将通过三个简单的实例,实际应用上篇文章的基础理论知识,展示下Flex布局是如何解决CSS布局问题. 一.垂直居中 这里同时用非flex布局和flex布局两种方式来实现,可以对比 ...

  3. Css animation 与 float 、flex 布局问题

    1. 有这样一段css html 代码 <div class="container"> <div class="float-left"> ...

  4. 解决flex布局下, elementui table组件不能跟随父组件的宽度而变化的bug

    bug: 我在flex布局的元素中使用了elementui的table组件,饿了么的table上会被加一个动态的宽度, 当第一次改变flex元素宽度的时候.table的动态宽度会变化,第二次和以后就不 ...

  5. css 位置居中篇,flex布局【转】

    最近看到沅老师的博客,关于flex布局的,觉得不错,http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

  6. CSS 小结笔记之伸缩布局 (flex)

    CSS flex 是一种伸缩布局,之前块级元素布局在同一行,可以通过display或position或float来实现,而本篇介绍一个新的方法——flex(弹性布局). flex 为和模型布局提供了极 ...

  7. CSS 小结笔记之em

    1.为什么使用em em也是css中的一种单位,和px类似.很多人会疑惑为什么有了px之后还要使用em,而且em使用起来相对于px来讲比较麻烦. em主要是应用于弹性布局,下面给出一个小栗子说明em的 ...

  8. CSS 小结笔记之BFC

    BFC 即为Block formatting context 的缩写,BFC 主要用来将一个盒子设置为一个隔离的容器,不管盒子内部的元素具有什么属性,都不会影响到盒子的外面. 1.哪些元素能产生BFC ...

  9. CSS 小结笔记之图标字体(IconFont)

    本篇主要介绍一种非常好用的图标大法——图标字体(IconFont). 什么是图标字体?顾名思义,它是一种字体,只不过这个字体显示的并不是具体的文字之类的,而是各种图标. 网站上经常会用到各种图标,之前 ...

随机推荐

  1. Mac OS X 下搭建thrift环境

    1.概述 thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和代码生产引擎,以构建在 C++, Java, Python, PHP, Ruby, Erlang, ...

  2. 比特币算法——SHA256算法介绍

    SHA256是安全散列算法SHA(Secure Hash Algorithm)系列算法之一,其摘要长度为256bits,即32个字节,故称SHA256.SHA系列算法是美国国家安全局 (NSA) 设计 ...

  3. Java反射机制二 获取方法的返回值或参数的泛型信息

    在使用反射机制时,我们经常需要知道方法的参数和返回值类型,很简单  ,下面上示例,示例中的两个方法非常相似 package deadLockThread; import java.lang.refle ...

  4. xunsearch使用记录

    部署,配置,有时间在记录 <?php namespace APPlib; class XSGameku { public $error; public $xs; public $search; ...

  5. Git 撤销与修改

    增补提交 git commit –C HEAD –a --amend -C表示复用指定提交的提交留言,这个例子中是HEAD,实际上可以指定其他有效的提交名称. 如果参数是小写的-c,就会打开预先设置好 ...

  6. 【转】常见六大Web 安全攻防解析

    原文转自:https://segmentfault.com/a/1190000018073845 作者:浪里行舟 在互联网时代,数据安全与个人隐私受到了前所未有的挑战,各种新奇的攻击技术层出不穷.如何 ...

  7. SpringMVC之REST

    REST: 即 Representational State Transfer.(资源)表现层状态转化.是目前最流行的一种互联网软件架构.它结构清晰.符合标准.易于理解.扩展方便,所以正得到越来越多网 ...

  8. Netbeans 8.0配置Python开发环境

    1. 菜单栏:工具->插件->设置->添加 配置如下信息: http://deadlock.netbeans.org/hudson/job/nbms-and-javadoc/last ...

  9. OAuth2.0的理解&基础

    此文章是复制黏贴网上文章的,主要做自己备用着看(也加了自己的一点见解),喜欢的读者也可以看. OAuth是一个关于授权(authorization)的开放网络标准,在全世界得到广泛应用,目前的版本是2 ...

  10. F5刷新缘何会引起表单重复提交

    首先,页面第一次加载,在未进行任何操作,表单没有提交过的前提下,此时点击F5刷新,是没有任何问题的. F5刷新引起表单重复提交 前提条件: 用户已通过 (1)submit按钮 (2)js的form.s ...