Blogger Information
Blog 15
fans 0
comment 0
visits 9277
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
1222 flex的简单练习
fanyigle_php
Original
747 people have browsed it
  1. 定位的布局思路练习

    1. <!DOCTYPE html>
    2. <html lang="zh-CN">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    6. <title>定位的布局思路练习</title>
    7. <!--
    8. 1.确定文档结构
    9. 2.样式的初始化
    10. 3.分块的样式设定
    11. -->
    12. <style>
    13. * {
    14. margin: 0;
    15. padding: 0;
    16. box-sizing: border-box;
    17. }
    18. header {
    19. background-color: antiquewhite;
    20. min-height: 10em;
    21. }
    22. .container {
    23. min-height: 20em;
    24. position: relative;
    25. margin: 1em 0;
    26. }
    27. .container aside:first-of-type {
    28. min-height: inherit;
    29. width: 5em;
    30. background-color: hotpink;
    31. position: absolute;
    32. top: 0;
    33. left: 0;
    34. }
    35. .container aside:last-of-type {
    36. min-height: inherit;
    37. width: 5em;
    38. background-color: darkgoldenrod;
    39. position: absolute;
    40. top: 0;
    41. right: 0;
    42. }
    43. .container main {
    44. min-height: inherit;
    45. background-color: darkmagenta;
    46. /* padding: 0 5em; */
    47. position: absolute;
    48. left: 5em;
    49. right: 5em;
    50. margin: 0 0.5em;
    51. }
    52. footer {
    53. background-color: aquamarine;
    54. min-height: 10em;
    55. }
    56. </style>
    57. </head>
    58. <body>
    59. <header>头部</header>
    60. <div class="container">
    61. <aside>左侧</aside>
    62. <main>主题</main>
    63. <aside>右侧</aside>
    64. </div>
    65. <footer>尾部</footer>
    66. </body>
    67. </html>
  2. flex实现水平和垂直居中

    1. <!DOCTYPE html>
    2. <html lang="zh-CN">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    6. <title>flex实现水平和垂直居中</title>
    7. <style>
    8. .box {
    9. width: 15em;
    10. height: 15em;
    11. background-color: aquamarine;
    12. position: relative;
    13. }
    14. .box .item {
    15. width: 5em;
    16. height: 5em;
    17. background-color: yellow;
    18. position: absolute;
    19. }
    20. /* .box .item {
    21. width: 5em;
    22. height: 5em;
    23. background-color: yellow;
    24. position: absolute;
    25. left: 0;
    26. top: 0;
    27. right: 0;
    28. bottom: 0;
    29. margin: auto;
    30. } */
    31. .box {
    32. display: flex;
    33. justify-content: center;
    34. align-items: center;
    35. }
    36. </style>
    37. </head>
    38. <body>
    39. <div class="box">
    40. <div class="item"></div>
    41. </div>
    42. </body>
    43. </html>
  3. 用flex写三列

    1. <!DOCTYPE html>
    2. <html lang="zh-CN">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    6. <title>flex写三列</title>
    7. <style>
    8. * {
    9. box-sizing: border-box;
    10. }
    11. /*实体元素改色可见*/
    12. body *:not(.container) {
    13. background-color: antiquewhite;
    14. }
    15. header,
    16. footer {
    17. height: 10vh;
    18. }
    19. .container {
    20. height: calc(80vh - 1em);
    21. margin: 0.5em 0;
    22. display: flex;
    23. }
    24. .container aside {
    25. min-width: 15em;
    26. }
    27. .container main {
    28. min-width: calc(100vw - 30em - 2em);
    29. margin: 0 1em;
    30. }
    31. </style>
    32. </head>
    33. <body>
    34. <header>头部</header>
    35. <div class="container">
    36. <aside>左侧</aside>
    37. <main>主题</main>
    38. <aside>右侧</aside>
    39. </div>
    40. <footer>尾部</footer>
    41. </body>
    42. </html>
  4. grid写三行三列

    1. <!DOCTYPE html>
    2. <html lang="zh-CN">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    6. <title>grid写三行三列</title>
    7. <style>
    8. body {
    9. height: 100vh;
    10. display: grid;
    11. grid-template-columns: 10em 1fr 10rem;
    12. grid-template-rows: 10vh 1fr 10vh;
    13. gap: 0.5em;
    14. }
    15. body > * {
    16. background-color: aqua;
    17. }
    18. header,
    19. footer {
    20. grid-column: span 3;
    21. }
    22. </style>
    23. </head>
    24. <body>
    25. <header>头部</header>
    26. <aside>左侧</aside>
    27. <main>主题</main>
    28. <aside>右侧</aside>
    29. <footer>尾部</footer>
    30. </body>
    31. </html>
  5. 弹性容器与子项目

    1. <!DOCTYPE html>
    2. <html lang="zh-CN">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    6. <title>弹性容器与子项目</title>
    7. <style>
    8. * {
    9. box-sizing: border-box;
    10. }
    11. .container {
    12. display: flex;
    13. height: 20em;
    14. padding: 1em;
    15. border: 1em dotted blue;
    16. }
    17. .item {
    18. width: 10em;
    19. height: 6em;
    20. border: 1px solid red;
    21. }
    22. .item:last-of-type {
    23. display: flex;
    24. }
    25. .subitem {
    26. border: 2px dashed green;
    27. }
    28. </style>
    29. </head>
    30. <body>
    31. <div class="container">
    32. <div class="item">item1</div>
    33. <div class="item">item2</div>
    34. <div class="item">
    35. item3
    36. <div class="subitem">subitem1</div>
    37. <div class="subitem">subitem2</div>
    38. <div class="subitem">subitem3</div>
    39. </div>
    40. </div>
    41. </body>
    42. </html>
  6. 项目的排列和换行
    1. <!DOCTYPE html>
    2. <html lang="zh-CN">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    6. <title>项目的排列和换行</title>
    7. <style>
    8. .container {
    9. display: flex;
    10. /* flex-direction: row;
    11. flex-wrap: wrap; */
    12. flex-flow: row wrap;
    13. height: 20em;
    14. /* width: 10em; */
    15. padding: 1em;
    16. border: 2px solid green;
    17. }
    18. .item {
    19. width: 5em;
    20. height: 4em;
    21. border: 1px solid red;
    22. }
    23. </style>
    24. </head>
    25. <body>
    26. <div class="container">
    27. <div class="item">item1</div>
    28. <div class="item">item2</div>
    29. <div class="item">item3</div>
    30. <div class="item">item4</div>
    31. <div class="item">item5</div>
    32. <div class="item">item6</div>
    33. <div class="item">item7</div>
    34. <div class="item">item8</div>
    35. </div>
    36. </body>
    37. </html>
  7. 项目在容器内的横纵对齐方式

    1. <!DOCTYPE html>
    2. <html lang="zh-CN">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    6. <title>项目在容器内的横纵对齐方式</title>
    7. <!--
    8. 对齐解决的是项目和留白区域的划分
    9. 1.项目在主轴上和交叉轴上有剩余空间则可以使用对齐,调整项目的位置;
    10. -->
    11. <style>
    12. .container {
    13. display: flex;
    14. /* flex-direction: row;
    15. flex-wrap: wrap; */
    16. flex-flow: row wrap;
    17. height: 20em;
    18. /* width: 10em; */
    19. padding: 1em;
    20. border: 2px solid green;
    21. }
    22. .item {
    23. width: 5em;
    24. height: 4em;
    25. border: 1px solid red;
    26. }
    27. .container {
    28. /*主轴上的对齐方式,水平移动*/
    29. /*1.所有项目无间隙排列*/
    30. justify-content: flex-start;
    31. justify-content: flex-end;
    32. justify-content: center;
    33. /*2.每个项目左右都有间隙*/
    34. justify-content: space-around;
    35. justify-content: space-between;
    36. justify-content: space-evenly;
    37. /*交叉轴上的对齐,垂直移动*/
    38. align-items: stretch;
    39. align-items: flex-start;
    40. align-items: flex-end;
    41. align-items: center;
    42. }
    43. </style>
    44. </head>
    45. <body>
    46. <div class="container">
    47. <div class="item">item1</div>
    48. <div class="item">item2</div>
    49. <div class="item">item3</div>
    50. <div class="item">item4</div>
    51. <div class="item">item5</div>
    52. <div class="item">item6</div>
    53. <div class="item">item7</div>
    54. </div>
    55. </body>
    56. </html>
  8. 多行项目在容器内的横纵对齐方式

    1. <!DOCTYPE html>
    2. <html lang="zh-CN">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    6. <title>多行项目在容器内的横纵对齐方式</title>
    7. <!--
    8. 对齐解决的是项目和留白区域的划分
    9. 1.项目在主轴上和交叉轴上有剩余空间则可以使用对齐,调整项目的位置;
    10. -->
    11. <style>
    12. .container {
    13. display: flex;
    14. /* flex-direction: row;
    15. flex-wrap: wrap; */
    16. flex-flow: row wrap;
    17. height: 20em;
    18. /* width: 10em; */
    19. padding: 1em;
    20. border: 2px solid green;
    21. }
    22. .item {
    23. width: 5em;
    24. height: 4em;
    25. border: 1px solid red;
    26. }
    27. .container {
    28. /*主轴上的对齐方式,水平移动*/
    29. /*1.所有项目无间隙排列*/
    30. justify-content: flex-start;
    31. justify-content: flex-end;
    32. justify-content: center;
    33. /*2.每个项目左右都有间隙*/
    34. /* justify-content: space-around;
    35. justify-content: space-between;*/
    36. justify-content: space-evenly;
    37. /*交叉轴上的对齐,垂直移动*/
    38. /*align-items先切割成多行,然后处理每行的交叉轴对齐*/
    39. align-items: stretch;
    40. align-items: flex-start;
    41. align-items: flex-end;
    42. /* align-items: center; */
    43. /*多行项目沿交叉轴无间隙,整体移动*/
    44. /* align-content: flex-end;
    45. align-content: flex-start; */
    46. /* align-content: center; */
    47. /*多行项目沿交叉轴有间隙调整*/
    48. /* align-content: space-between;
    49. align-content: space-evenly;*/
    50. align-content: space-around;
    51. }
    52. </style>
    53. </head>
    54. <body>
    55. <div class="container">
    56. <div class="item">item1</div>
    57. <div class="item">item2</div>
    58. <div class="item">item3</div>
    59. <div class="item">item4</div>
    60. <div class="item">item5</div>
    61. <div class="item">item6</div>
    62. <div class="item">item7</div>
    63. <div class="item">item8</div>
    64. <div class="item">item9</div>
    65. <div class="item">item10</div>
    66. <div class="item">item11</div>
    67. <div class="item">item12</div>
    68. </div>
    69. </body>
    70. </html>
  9. 项目的flex属性\order属性\align-self属性

    1. <!DOCTYPE html>
    2. <html lang="zh-CN">
    3. <head>
    4. <meta charset="UTF-8" />
    5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    6. <title>项目的flex属性\order属性\align-self属性</title>
    7. <!--改变项目大小\交叉轴对齐\在容器中的顺序-->
    8. <style>
    9. .container {
    10. display: flex;
    11. /* flex-direction: row;
    12. flex-wrap: wrap; */
    13. flex-flow: row nowrap;
    14. height: 20em;
    15. /* width: 10em; */
    16. padding: 1em;
    17. border: 2px solid green;
    18. }
    19. .item {
    20. width: 5em;
    21. /* height: 4em; */
    22. border: 1px solid red;
    23. }
    24. .container .item {
    25. /* 默认值 */
    26. flex: 0 1 auto;
    27. flex: initial;
    28. /*允许放大*/
    29. flex: 1 1 auto;
    30. flex: auto;
    31. flex: 1;
    32. /*禁止放大和缩小*/
    33. flex: 0 0 auto;
    34. flex: none;
    35. /*test*/
    36. flex: 3;
    37. }
    38. .container > .item:last-of-type,
    39. .container > .item:nth-of-type(2) {
    40. flex: 1;
    41. }
    42. /*设置某一个项目在交叉轴上的对齐方式*/
    43. .container > .item:first-child {
    44. align-self: flex-start;
    45. }
    46. /*项目的order属性*/
    47. .container .item:nth-child(2) {
    48. order: -1;
    49. }
    50. </style>
    51. </head>
    52. <body>
    53. <div class="container">
    54. <div class="item">item1</div>
    55. <div class="item">item2</div>
    56. <div class="item">item3</div>
    57. <div class="item">item4</div>
    58. <div class="item">item5</div>
    59. <div class="item">item6</div>
    60. <div class="item">item7</div>
    61. <div class="item">item8</div>
    62. <div class="item">item9</div>
    63. </div>
    64. </body>
    65. </html>
Correcting teacher:天蓬老师天蓬老师

Correction status:qualified

Teacher's comments:
Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post