小程序开发-第一章第四节从block盒式布局到Flex弹性布局-全栈工程师之路-中级篇(上)

简介: 小程序开发-第一章第四节从block盒式布局到Flex弹性布局-全栈工程师之路-中级篇(上)

说明:为了便于理解和分析,此处我们全部使用块级元素div来进行说明。因为要将这个文档应用于博客,所以所有的样式写在style中。公众号不支持,博客样式支持不好,又重新上传了图片,替换了展示效果(泪目)。标题一二三不代表这些概念同级,仅仅代表本文提到的顺序。


关于盒式布局的定义和说明,请自行搜索了解,此处不做详细说明。我这里引入几个概念,是我自己理解所得,不权威,但有利于学习和理解。


一、块block

我把页面中宽度占满屏幕,高度任意的元素(或者区域)成为块。不管是盒式布局中常提到的上中下结构、左右结构和复杂结构,都可以用这个概念简化。

如:上中下结构,可将下图的页头、主体和页脚视为三个块。

image.png

如:左右结构,可将菜单和主体组合起来的整体视为一个块。如下所示,绿色框框视为一个块。

image.png

如:复杂结构,也是一样的将页面分成独立的块。不管里面元素的布局,先从整体上分析和实现。


二、项item

其实项的概念和块的概念相同,只是把同样概念的-宽度占满屏幕,高度任意的一个块称为项。

如:常用移动页面的首页

image.png

如上图所示,我将图中红色边框的块称为一个项,并不理会项中是单一元素还是复杂元素。如第一项中单一的banner,第二项中四个菜单按钮,和最后那几个项中的左右上下结构。

其实上图中的标题和详细说明,这个上下结构也可以理解为一个项,只是它是放在外层大项中的小项。

image.png


三、Flex弹性布局

理解了上述两个概念,接下来我们就比较容易理解Flex弹性布局了。要是用弹性布局,块级元素设置display:flex;行内元素设置display:inline-flex;将该元素设置为Flex容器。表明该元素内的子元素将使用弹性布局。注意设置成Flex容器之后,内部子元素(以下称为子项)的浮动和对齐属性都会失效。接下来我们对Flex容器的各个属性进行说明。


  • flex-direction 子项的排列方向,分为从左到右,从右到左,从上到下,从下到上
  • flex-wrap 子项排列不下之后是否换行,分为不换行,排到下一行,排到上一行
  • flex-flow 上面两个属性的组合,如可以直接设置从左到右排列,排不下排到下一行。
  • justify-content 子项在排列方向上的对齐方式,(横向说明)分为左对齐,右对齐,居中对齐,两端对齐中间等分布局和全部等间距布局
  • align-items 子项在另一个方向上的对齐方式,(横向说明)分为上对齐,下对齐,居中对齐,上下拉伸充满,子项首行文字对齐
  • align-content 在子项内容排列多行时整体的对齐方式(就是设置行和行之间的排列),分为全部靠上、全部靠下、居中等,IE、Safari、Firefox不支持这个属性(小程序中完全支持)

1、flex-direction 子项的排列方向,分为从左到右,从右到左,从上到下,从下到上

1.1 row 从左到右display: flex;flex-direction:row;

<div style="padding: 10px;border: 1px solid black;display: flex;flex-direction:row;">  
<div style="border: 1px solid red;">页头</div>  
 <div style="border: 1px solid blue;">主体</div>  
<div style="border: 1px solid green;">页脚</div>  
</div>  

image.png

1.2 row-reverse 从右到左display: flex;flex-direction:row-reverse;

image.png

1.3 column 从上到下display: flex;flex-direction:column;

image.png

1.4 column-reverse 从下到上display: flex;flex-direction:column-reverse;

image.png

2、flex-wrap 子项排列不下之后是否换行,分为不换行,排到下一行,排到上一行

2.1 nowrap 不换行display: flex;flex-direction:row;flex-wrap:nowrap;

<div style="width:120px;padding: 10px;border: 1px solid black;display: flex;flex-direction:row;flex-wrap: nowrap;">  
<div style="width:50px;border: 1px solid red;">页头</div>  
<div style="width:50px;border: 1px solid blue;">主体</div>  
<div style="width:50px;border: 1px solid green;">页脚</div>  
</div>  

这里外层容器和子项都设置了宽度,但实际的并没有效果,会自动扩展。

image.png

2.2 wrap 排到下一行display: flex;flex-direction:row;flex-wrap:wrap;


image.png

2.3 wrap-reverse 排到上一行display: flex;flex-direction:row;flex-wrap:wrap-reverse;

image.png

3、flex-flow 上面两个属性的组合,如可以直接设置从左到右排列,排不下排到下一行

<div style="width:120px;padding: 10px;border: 1px solid black;display: flex;flex-flow:row wrap;">  
<div style="width:50px;border: 1px solid red;">页头</div>  
<div style="width:50px;border: 1px solid blue;">主体</div>  
<div style="width:50px;border: 1px solid green;">页脚</div>  
</div>  

image.png


目录
相关文章
预约按摩小程序开发,为什么很多上门按摩平台根本招聘不到优秀技师?
上门按摩平台面临招不到优秀技师的问题,主要原因是平台众多,技师选择多样。为解决此问题,平台可引入技师等级制度,根据订单数量和好评率划分高、低等级技师。高等级技师可享受70%-90%的高提成及首页推荐,这不仅能激励技师的积极性,还能帮助平台筛选出优质技师,提升服务质量和口碑,形成良性循环。
|
7天前
|
容器
HTML中使用Flex布局实现双行夹批效果
在HTML中,还可以用table元素来实现双行夹批效果,但比flex布局代码更复杂,效果也不见得更理想。
|
3天前
|
小程序 云计算 Android开发
发者社区 云计算 文章 正文 小程序开发与公众号用户关联推送消息(九)
发者社区 云计算 文章 正文 小程序开发与公众号用户关联推送消息(九)
17 3
|
9天前
|
开发者 UED 容器
鸿蒙next版开发:ArkTS组件通用属性(Flex布局)
在HarmonyOS next中,ArkTS的Flex布局是一种强大且灵活的布局方式,支持水平或垂直方向排列元素,并能动态调整大小和位置以适应不同屏幕。主要属性包括justifyContent、alignItems、direction和wrap,适用于导航栏、侧边栏和表单等多种场景。示例代码展示了如何使用这些属性创建美观的布局。
34 10
|
9天前
|
小程序
|
9天前
|
小程序
|
30天前
|
移动开发 小程序 数据可视化
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
203 3
|
1月前
|
小程序 API
微信小程序更新提醒uniapp
在小程序开发中,版本更新至关重要。本方案利用 `uni-app` 的 `uni.getUpdateManager()` API 在启动时检测版本更新,提示用户并提供立即更新选项,自动下载更新内容,并在更新完成后重启小程序以应用新版本。适用于微信小程序,确保用户始终使用最新版本。以下是实现步骤: ### 实现步骤 1. **创建更新方法**:在 `App.vue` 中创建 `updateApp` 方法用于检查小程序是否有新版本。 2. **测试**:添加编译模式并选择成功状态进行模拟测试。
48 0
微信小程序更新提醒uniapp
|
3月前
|
小程序 前端开发 Java
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
JavaDog Chat v1.0.0 是一款基于 SpringBoot、MybatisPlus 和 uniapp 的简易聊天软件,兼容 H5、小程序和 APP,提供丰富的注释和简洁代码,适合初学者。主要功能包括登录注册、消息发送、好友管理及群组交流。
104 0
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目

热门文章

最新文章