flex布局之flex-basis采坑
场景:
容器设置为display: flex,容器里的子项目部分设置 flex: auto,子项目的宽高自适应正常,但如果再往子项目里嵌套一个(如:div),并设置高度(如:height: 100%),发现该元素高度不符合预期。
源码:
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<meta charset="utf-8">
<title></title>
<style media="screen">
html,body{
margin: 0px;
padding: 0px;
height: 99%;
}
div{
padding: 5px 10px;
border: 1px solid silver;
}
.container {
height: 90%;
}
.flex{
display: flex;
flex-direction: column;
}
.item {
flex: 1 1 auto;
overflow: auto;
}
</style>
</head>
<body>
<div class="flex container">
<div class="">
<h3>头部信息 - 未设置高度信息</h3>
</div>
<hr>
<div class="item">
flex: auto时高度自适应情况
<div class="container">
内部嵌套要求自适应高度(百分比)的div
</div>
</div>
</div>
</body>
</html>
不符预期图:

预期效果图:

为达到预期其实只对样式略微做了调整:
.item {
    flex: 1 1 100%;
    overflow: auto;
}
flex是一种简写,最后一个值其实就是对应flex-basis的设置,如果同时设置flex-basis和height,那么height属性会被覆盖,也就是说flex-basis的优先级比height高。有一点需要注意,如果flex-basis和width其中有一个是auto,那么另外一个非auto的属性优先级会更高。
如果这是设置后,依然出现height: 100%无效,可以查看父级是有flex-basis:auto的情况
												
											flex布局之flex-basis采坑的更多相关文章
- flex布局中flex属性运用在随机发红包的算法上
		
flex布局是现在前端基本上都会运用的一种布局,基本上用到比较多的是父元素设置display:flex,两个子元素,一个设置固定宽度,另一个设置为flex:1(这里都指flex-direction为r ...
 - 重新总结flex布局(flex,flex-direction,justify-content,align-items,flex-wrap,align-self)
		
1.flex,主要就是按比例分配.(例如:两个div的flex:1,就大小相等) .box1{ flex:1; background-color: red; } .box2{ flex:1; back ...
 - 微信小程序开发之搞懂flex布局2——flex container
		
容器的概念,是用来包含其它容器(container)和项目(item). flex container——flex容器 A flexbox layout is defined using the fl ...
 - 微信小程序开发之搞懂flex布局3——Flex Item
		
Flex Item flex容器的子元素就是这个容器的flex item. The direct children of a Flex Container (elements with display ...
 - [flex布局]-flex教程
		
简介:2009年,W3C提出了一种新的方案----Flex布局,可以简便.完整.响应式地实现各种页面布局.目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能. Flex布局是什 ...
 - 微信小程序开发:Flex布局
		
微信小程序页面布局方式采用的是Flex布局.Flex布局,是W3c在2009年提出的一种新的方案,可以简便,完整,响应式的实现各种页面布局.Flex布局提供了元素在容器中的对齐,方向以及顺序,甚至他们 ...
 - 使用Sass优雅并高效的实现CSS中的垂直水平居中(附带Flex布局,CSS3+SASS完美版)
		
实现css水平垂直居中的方法有很多,在这里我简单的说下四种比较常用的方法: 1.使用CSS3中的Flex布局 对于flex,我们要了解的是它是一个display的属性,而且必须要给他的父元素设置fle ...
 - flex布局的使用,纪念第一次开发手机网站
		
一直专注于PC网站的开发,不曾接触手机网站,于今日机缘巧合也是公司业务需要,并在之前学习过flex的布局,于是一并实践.碰到的问题还是很多的,主要是谈谈flex布局. flex布局是css3里的内容, ...
 - flex布局小记
		
越来越深刻的感到日事日毕的必要性,很久之前就做了备忘说要深刻学习flex布局,没想到一拖就拖到了这个时候! 一,什么是flex布局: flex布局即flexible box布局,也就是弹性盒模型或者弹 ...
 - CSS实例详解:Flex布局
		
本文由云+社区发表 本文将通过三个简单的实例,实际应用上篇文章的基础理论知识,展示下Flex布局是如何解决CSS布局问题. 一.垂直居中 这里同时用非flex布局和flex布局两种方式来实现,可以对比 ...
 
随机推荐
- codeblock用法
			
1.链接动态库.so和静态库.a settings->compiler->linker settings->add 2.编译报错ld return 1 exit status 一般来 ...
 - Redis 存储数组
			
我们知道Redis是不可以直接存储数组的. 我们只需在存储数组之前序列化(serialize)一下, 然后获取的时候反序列化(unserialize) 就解决这个问题了!
 - 199. Spring Boot JNDI:这是虾米?
			
[视频&交流平台] àSpringBoot视频:http://t.cn/R3QepWG à SpringCloud视频:http://t.cn/R3QeRZc à Spring Boot源 ...
 - mysql数据库存中文字段
			
mysql数据默认编码是拉丁,而我们更多的使用utf8, 在创建库的时候执行参数即可: CREATE DATABASE IF NOT EXISTS yourdbname DEFAULT CHARSET ...
 - linux 查看端口被占用
			
linux 查看端口被占用 1.lsof -i : 端口号 用于查看某一端口的占用情况,比如查看8080端口使用情况,lsof -i:8080 如果执行 lsof -i:8080 系统提示 : ...
 - 小程序获取微信用户的openid
			
小程序获取微信用户的openid //index.js //获取应用实例 const app = getApp() Page({ globalData: { appid: '11121221a89e0 ...
 - 60.纯 CSS 创作一块乐高积木
			
原文地址:https://segmentfault.com/a/1190000015369542 感想:y轴旋转,相对定位,今天有点懵呀,唉. HTML code: <!-- 定义dom,容器中 ...
 - myeclipse和jdk的安装和配置
			
一.安装JDK 1.下载得到jdk-8u11-windows-i586.1406279697.exe,直接双击运行安装,一直next就可以,默认是安装到系统盘下面Program Files,我这里装在 ...
 - 30_react_router基本使用
			
项目结构: import React from 'react' import {render} from 'react-dom' import {BrowserRouter} from 'react- ...
 - js 生成手机图片并保存到相册
			
1.注意权限问题 2.调用HTML5+api 3.优化显示 4.注意兼容ios.Android