zoukankan      html  css  js  c++  java
  • 移动端:Flex弹性盒布局

    Flex弹性盒布局


    一、 Flex的发展史

    1. 2009年W3C 提出概念,但是官方没有flex这个词
    2. 2011年浏览器厂商决定使用flexbox,来形容它的布局特点
    3. 2015年W3C正式将其修改为flexbox布局
    4. 2016年5月官方正式公布最新的稳定的flex布局规范标准,各大浏览器的支持越来越稳定

    二、 定义

    1. Flex是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性
    2. 作用
      • 它能够更加高效方便的控制元素的对齐、排列
      • 可以自动计算布局内元素的尺寸,无论这个元素的尺寸是固定的还是动态的
      • 控制元素在页面的布局方向
      • 按照不同于DOM[文档对象模型] 所指定排序方式对屏幕上的元素重新排序

    三、 布局方式分类

    1. 行内级、块级布局
    2. 表格布局
    3. 浮动、定位布局
    4. Flex布局
    5. 网格矩阵形式的布局

    四、 应用场景

    1. 使用在现代浏览器中
    2. 有一定宽容度要求的设计中
      • 相对:宽容度要求较高
      • 绝对:宽容度要求较低,100%还原设计稿

    五、 Flex基本概念

    1. 采用Flex布局的元素,称为Flex容器(flex container),简称”容器”。它的所有子元素自动成为容器成员,称为Flex项目(flex item),简称”项目”
    2. 水平主轴(main axis)
    3. 垂直交叉轴(cross axis)
    4. 项目默认沿主轴排列

     六、 Flex布局语法

    七、容器的属性

    *      flex-direction的改变,一些依赖于主轴定义的属性也跟着改变
      • justify-conten    align-content    align-items
    • 容器转为flex布局之后,项目不受float的影响
    • flex-wrap的默认是nowrap,我们需要设置才会自动换行

    八、项目的属性

    九、 flex兼容性处理

    1. 添加浏览器前缀
    2. 使用sublime的autoprefixer插件进行前缀补全
    • 打开sublime下载、安装 autoprefixer 插件
    • 设置快捷键:选择菜单 Preferences > Key Bindings – User,可自定义
    • { "keys": ["ctrl+alt+p"], "command": "autoprefixer" }
    • 设置成功,在css里面写transition:all 2s,执行快捷键时候自动编译成 -webkit-transition:all 2s;transition:all 2s;原来sublime的插件autoprefixer默认是没有兼容IE、firefox和opera的
    • 如何配置兼容IE、firefox和opera等
      • 选择菜单:Preferences > Package Settings > Autoprefixer > Settings - User 为浏览最新版本添加前缀,市场份额大于0.1%,美国份额>5%,ie6-ie8,火狐版本20以下等
      • "browsers": ["last 2 version", "> 0.1%", "> 5% in US", "ie 6-8","Firefox < 20"]

     

     

     

     

  • 相关阅读:
    [LeetCode] 638. Shopping Offers
    [LeetCode] 1436. Destination City
    [LeetCode] 405. Convert a Number to Hexadecimal
    [LeetCode] 1909. Remove One Element to Make the Array Strictly Increasing
    [LeetCode] 1475. Final Prices With a Special Discount in a Shop
    [LeetCode] 650. 2 Keys Keyboard
    [LeetCode] 1382. Balance a Binary Search Tree
    [LeetCode] 917. Reverse Only Letters
    [LeetCode] 1189. Maximum Number of Balloons
    [LeetCode] 447. Number of Boomerangs
  • 原文地址:https://www.cnblogs.com/guisenbin/p/10451829.html
Copyright © 2011-2022 走看看