Blogger Information
Blog 30
fans 0
comment 0
visits 13901
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
移动端布局思路与视口之间关系并实例演示基本架构
天宁
Original
330 people have browsed it

移动端布局思路与视口之间关系并实例演示基本架构

移动端布局思路

  • 视图统一
    • 设置布局视图和视觉视图统width=device-width
    • 理想视图与视觉视图统一inintial-scale=1.0
  • 把之前使用的px转换成rem
    • 为方便计算,将 1rem 设置为 100px,一般以屏幕宽度(375px)为基准,为方便计算,将 1rem 设置为 100px,100px=100vw/1vw=100vw/(375/100)=100vw/3.75
  • 把根元素中的字体大小改成浏览器默认的 16px
    • 因为已经改成 1rem=100px,所有这里的 16px 为 0.16rem
      1. body {
      2. font-size: 0.16rem;
      3. }
  • 限制一下手机上最大最小字号
    • 通过媒体查询的方式设置,这里不能使用rem,不然不同手机宽度可能就超出或很小
      1. /* 最小的字号,宽度小于等于320px采用的样式 */
      2. @media screen and (max-width: 320px) {
      3. :root {
      4. font-size: 85px;
      5. }
      6. }
      7. /* 最大的字号,宽度大于等于640px采用的样式 */
      8. @media screen and (min-width: 640px) {
      9. :root {
      10. font-size: 170px;
      11. }
      12. }

三种视口之间的关系

  • 布局视口Layout viewport
    • 设备无关, 通常默认980px,显示完整网页
  • 视觉视口visual viewport
    • 设备相关,用户手机屏幕可见部分,通过缩放查看全部
  • 理想视口idea viewport
    • 不必缩放就可查看全部,针对移动端进行布局

手机页面的基本整体架构

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  7. <title>手机页面布局整体架构</title>
  8. <link rel="stylesheet" href="css/reset.css" />
  9. <style>
  10. /* 顶部 */
  11. header {
  12. position: relative;
  13. }
  14. /* logo和搜索框布局 */
  15. header .top {
  16. position: fixed;
  17. display: flex;
  18. width: 100vw;
  19. justify-content: space-between;
  20. padding: 0.05rem 0.15rem;
  21. background-color: rgb(228, 114, 8);
  22. }
  23. /* 设置一下搜索框宽度 */
  24. header .top .search input {
  25. width: 70vw;
  26. }
  27. /* 把轮播图的位置设置出来 */
  28. header .carousel {
  29. position: absolute;
  30. top: 0.29rem;
  31. height: 1.17rem;
  32. }
  33. /* 轮播图设置宽度 */
  34. header .carousel img {
  35. width: 100vw;
  36. }
  37. /* 导航组 */
  38. header .nav {
  39. position: absolute;
  40. top: calc(0.29rem + 1.17rem);
  41. height: 1.5rem;
  42. display: grid;
  43. width: 100vw;
  44. grid-template-columns: repeat(4, 1fr);
  45. grid-template-rows: repeat(2, 1fr);
  46. place-items: center;
  47. }
  48. /* 主体部分 */
  49. main {
  50. position: relative;
  51. top: calc(0.29rem + 1.17rem + 1.5rem);
  52. padding: 0.1rem;
  53. }
  54. /* 主体部分字体颜色等 */
  55. main div {
  56. color: red;
  57. font-size: 0.3rem;
  58. font-weight: bolder;
  59. text-align: center;
  60. }
  61. /* 底部菜单栏做个固定定位 */
  62. footer {
  63. position: fixed;
  64. top: calc(100vh - 0.46rem);
  65. background-color: #fff;
  66. }
  67. /* 底部布局 */
  68. footer .menu {
  69. display: flex;
  70. width: 100vw;
  71. height: 0.46rem;
  72. justify-content: space-around;
  73. align-items: center;
  74. }
  75. </style>
  76. </head>
  77. <body>
  78. <!-- 页眉 -->
  79. <header>
  80. <div class="top">
  81. <!-- 顶部logo和搜索框等 -->
  82. <div class="logo">图标</div>
  83. <div class="search">
  84. <input type="search" placeholder="我是搜索框" />
  85. </div>
  86. </div>
  87. <div class="carousel">
  88. <!-- 轮播图 -->
  89. <img src="image/1.jpg" alt="" />
  90. </div>
  91. <ul class="nav">
  92. <li>分类1</li>
  93. <li>分类2</li>
  94. <li>分类3</li>
  95. <li>分类4</li>
  96. <li>分类5</li>
  97. <li>分类6</li>
  98. <li>分类7</li>
  99. <li>分类8</li>
  100. </ul>
  101. </header>
  102. <!-- 主体 -->
  103. <main>
  104. <!-- 主体内容,根据不同需要进行具体操作 -->
  105. <div>
  106. <p>我是主体1</p>
  107. <p>我是主体2</p>
  108. <p>我是主体3</p>
  109. <p>我是主体4</p>
  110. <p>我是主体5</p>
  111. <p>我是主体6</p>
  112. <p>我是主体</p>
  113. <p>我是主体</p>
  114. <p>我是主体</p>
  115. <p>我是主体</p>
  116. <p>我是主体</p>
  117. <p>我是主体</p>
  118. <p>我是主体</p>
  119. <p>我是主体</p>
  120. <p>我是主体</p>
  121. <p>我是主体999</p>
  122. </div>
  123. </main>
  124. <!-- 页脚 -->
  125. <footer>
  126. <!-- 底部菜单栏,一般是首页,我的等按钮 -->
  127. <ul class="menu">
  128. <li>菜单1</li>
  129. <li>菜单2</li>
  130. <li>菜单3</li>
  131. <li>菜单4</li>
  132. </ul>
  133. </footer>
  134. </body>
  135. </html>
Correcting teacher:PHPzPHPz

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