参考博客:http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

flex布局是w3c于09年提出的,用于简便,整洁,响应式地解决布局问题的手段,例如垂直居中布局。flex全称Flexible Box,也称“弹性布局”。

块级元素设置flex布局:display:flex

行内元素设置flex布局:display:inline-flex

当设置flex属性之后,元素的float,vertical-align和clear样式将失效。

flex主要属性:主轴(main axis)+交叉轴(cross axis),主轴开始位置(main start),结束位置(main end),交叉轴开始位置(cross start),结束位置(cross end),单个项目占据的主轴空间(main size),单个项目占据的交叉轴空间(cross size)

一、容器的属性(6个)

1.flex-direction,决定了主轴的方向,属性值如下:

row:水平方向,起点在左边

row-reverse:水平方向,起点在右边

column:垂直方向,起点在上边

column-reverse:垂直方向,起点在下边

2.flex-wrap,定义了如果轴线排不下如何换行

nowrap:默认不换行

wrap:换行

wrap-reverse:换行,第一行在下方

3.felx-flow:flex-direction+flex-wrap,如写作:flex-flow:row wrap

4.justify-content:定义了元素在主轴的对齐方式

5.align-items:定义了元素在交叉轴的对齐方式

6.align-content:定义了多行情况下(多根轴线)的对齐方式,只有一根轴线的话该属性无效

二、项目属性(6个)

1.order:定义项目的排列顺序,数值越小越靠前,默认为0

2.flex-grow:定义项目的放大比例,默认为0,空间足够也不放大

3.flex-shrink(无负值):定义项目的缩小比例,默认为1,空间不够则缩小

4.flex-basis:定义了项目占据的主轴空间,如设置flex-basis:300px,则项目占据固定大小,默认auto

5.flex:上述2-4的属性的汇总写法,默认0,1,auto,快捷写法:auto(1 1 auto)和none(0 0 auto)

6.align-self:允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性,默认继承align-items属性,

三、利用flex布局来优化项目布局,效果如下:

1.导航条

样式设置如下,主轴用了space-around布局,交叉轴用了center属性,利用flex布局来实现水平垂直居中真的是很简单。

#nav-bar {
display: flex;
justify-content: space-around;
align-items: center;
height: 80px;
background-color: #2C3E50;
}

2.主页面

因为目前主页面的内容实在是太少了,所以想着要做一个效果就是让div自动填满屏幕余下的高度,也就是上图效果,清晰一点用手机看的话是这样,一直铺满余下空间:

正确简单的做法是利用flex布局:

1.给html body标签都设置height:100%

2.上图div的父div设置为flex布局,项目里父div是#app,样式如下:

    #app {
display: flex;
flex-direction: column;
height: 100%;
}

3.然后是设置上图div,添加样式:flex:1,如下:

#main-page {
flex:; /*这个属性是为了让div填满剩余屏幕高度*/
width: 100%;
background-color: #DCDCDC;
}

ps:还有另外一种实现方法,但是存在问题,就是直接设置子div(#main-page)的height:100%,但是这样会存在一个问题,因为项目中导航条这个div是有固定高度80px的,所以如果设置了#main-page的height:100%,那么页面高度会溢出80px,也就是会出现滚动条,目前没有想到比较好的解决方法。

后面基本都是利用felx布局把页面布局全部修改了一遍,还是比较简单的。

FreeMusic项目优化(一)——flex布局学习记录的更多相关文章

  1. flex 布局学习

    flex 布局学习 寻根溯源话布局 一切都始于这样一个问题:怎样通过 CSS 简单而优雅的实现水平.垂直同时居中.记得刚开始学习 CSS 的时候,看到 float 属性不由得感觉眼前一亮,顺理成章的联 ...

  2. Flex 项目属性:flex 布局示例

    flex属性: flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto.后两个属性可选. 该属性有两个快捷值:auto (1 1 auto ...

  3. CSS flex 布局学习笔记

    写在前面 Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性. 任何一个容器都可以指定为 Flex 布局. 采用 Flex 布局的元素 ...

  4. Flex布局学习笔记

    任何元素都可以使用Flex布局,包括行内元素 display: flex; display: inline-flex使用Flex布局之后,子元素的float, clear, vertical-alig ...

  5. flex布局学习

    教程来自阮一峰的flex布局教程实例篇 容器五大属性: flex-direction:容器内项目的排列方向 (1)row:横向从左往右排列(默认) (2)row-reverse:横向从右往左排列 (3 ...

  6. flex布局学习总结

    最近项目主要是小程序,小程序里面的布局主要采用flex布局,之前对flex 布局只是稍作了解,总结下flex 布局的常用套路 容器 Flex是Flexible Box的缩写,意为"弹性布局& ...

  7. Flex 布局学习笔记

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  8. 前端flex布局学习笔记

    flex布局,即为弹性布局,其为盒模型提供最大的灵活性,任何一个容器都可以指定为flex布局. eg:.box{ display:flex: } 行内元素也可以使用flex布局. 注意:设置flex布 ...

  9. flex布局学习总结--阮一峰

    基本概念:   采用 Flex 布局的元素,称为 Flex 容器(flex container),简称"容器".它的所有子元素自动成为容器成员,称为 Flex 项目(flex it ...

随机推荐

  1. SecureCRT远程连接虚拟机CentOS的三种方式

    当在VMware虚拟机中将CentOS安装成功后,会在win7系统中模拟出两个虚拟网卡:VMnet1和VMnet8,我们来查看一下,点击“控制面板—>查看网络状态和任务—>更改适配器设置” ...

  2. eclipse 切换数据库

    PS:jdbc.url = 后面的路径就是连接的数据库,如果需要连接开发库(dev_cfin),则只需要将tg_cfin 换成 dev_cfin,重启后台即可.

  3. 使用IntelliJ IDEA配置Tomcat(入门)

    一.下载Tomcat 1.进入官网http://tomcat.apache.org/,选择download,下载所需Tomcat版本. 此处我们选择下载最新版本Tomcat 9. 注意有zip和exe ...

  4. vector 大小

    vector定义以后就最好确定大小resize(),否则在vector析构时可能出现 "double free or corruption"这样的错误

  5. 【网络爬虫】【python】网络爬虫(一):python爬虫概述

    python爬虫的实现方式: 1.简单点的urllib2 + regex,足够了,可以实现最基本的网页下载功能.实现思路就是前面java版爬虫差不多,把网页拉回来,再正则regex解析信息--总结起来 ...

  6. Identity Server 4 原理和实战(完结)_Authorization Code Flow 实例

    Code在Oauth2.0和OpenId Connect里面分别叫做不同的名字 OAuth只介绍了如何授权.没有介绍如何身份认证. OpenId Connect:既规定了怎么授权,也规定了怎么身份认证 ...

  7. Ubuntu18.04安装和配置Java JDK11并卸载自带OpenJDK

    卸载自带的OpenJDK方法: 在终端执行命令:sudo apt-get remove openjdk* Ubuntu18.04安装JDK11.0.2 前面步骤一样,可参考:https://www.c ...

  8. 模板 - 数据结构 - ST表 + 二维ST表

    区间最大值,$O(nlogn)$ 预处理,$O(1)$ 查询,不能动态修改.在查询次数M显著大于元素数量N的时候看得出差距. 令 $f[i][j]$ 表示 $[i,i+2^j-1]$ 的最大值. 显然 ...

  9. 201621123016 《Java程序设计》第5周学习总结

    1. 本周学习总结 1.1 写出你认为本周学习中比较重要的知识点关键词 关键字:接口,多态,Comparable,Comparator 1.2 尝试使用思维导图将这些关键词组织起来.注:思维导图一般不 ...

  10. ajaxForm上传文件到本地服务器(封装)

    不啰嗦,直接看代码 1.html: <div class="con-item fix"> <span class="f">文章封面< ...