登录
注册
模板
购买
商业授权
主机域名
专业授权
易优代理
易优+
应用
源码
插件
问答
帮助
视频教程
易优技巧
常见问题
易优手册
标签工具
更多
小程序
组件库
案例库
小程序模板网
首页
小程序模板网
开发文档
小程序开发教程
正文
微信小程序开发--从block盒式布局到Flex弹性布局
发布时间:2018-04-23 11:11
所属栏目:
小程序开发教程
说明:为了便于理解和分析,此处我们全部使用块级元素div来进行说明。因为要将这个文档应用于博客,所以所有的样式写在style中。公众号不支持,博客样式支持不好,又重新上传了图片,替换了展示效果(泪目)。你们能懂用纯文本编辑器编辑了一天,发现不能用的心情嘛!
标题一二三不代表这些概念同级,仅仅代表本文提到的顺序。
关于盒式布局的定义和说明,请自行搜索了解,此处不做详细说明。我这里引入几个概念,是我自己理解所得,不权威,但有利于学习和理解。
一、块block
我把页面中宽度占满屏幕,高度任意的元素(或者区域)称为块。不管是盒式布局中常提到的上中下结构、左右结构和复杂结构,都可以用这个概念简化。
如:上中下结构,可将下图的页头、主体和页脚视为三个块。
如:左右结构,可将菜单和主体组合起来的整体视为一个块。如下所示,绿色框框视为一个块。
如:复杂结构,也是一样的将页面分成独立的块。不管里面元素的布局,先从整体上分析和实现。
二、项item
其实项的概念和块的概念相同,只是把同样概念的-宽度占满屏幕,高度任意的一个块称为项。
如:常用移动页面的首页
如上图所示,我将图中红色边框的块称为一个项,并不理会项中是单一元素还是复杂元素。如第一项中单一的banner,第二项中四个菜单按钮,和最后那几个项中的左右上下结构。
其实上图中的标题和详细说明,这个上下结构也可以理解为一个项,只是它是放在外层大项中的小项。
三、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;
[html] view plain copy
<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>
1.2 row-reverse 从右到左display: flex;flex-direction:row-reverse;
1.3 column 从上到下display: flex;flex-direction:column;
1.4 column-reverse 从下到上display: flex;flex-direction:column-reverse;
2、flex-wrap 子项排列不下之后是否换行,分为不换行,排到下一行,排到上一行
2.1 nowrap 不换行display: flex;flex-direction:row;flex-wrap:nowrap;
[html] view plain copy
<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>
这里外层容器和子项都设置了宽度,但实际的并没有效果,会自动扩展。
2.2 wrap 排到下一行display: flex;flex-direction:row;flex-wrap:wrap;
2.3 wrap-reverse 排到上一行display: flex;flex-direction:row;flex-wrap:wrap-reverse;
3、flex-flow 上面两个属性的组合,如可以直接设置从左到右排列,排不下排到下一行
[html] view plain copy
<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=
易优小程序(企业版)+灵活api+前后代码开源
码云仓库:
本文地址:https://www.eyoucms.com/wxmini/doc/course/23899.html
复制链接
如需定制请联系易优客服咨询:800182392
点击咨询
热门问题
最新问题
1
微信小程序自定义组件 - 表格组件来啦
2
微信小程序自定义navigationBar顶部导航栏,兼容适配所有机型(附完整案例)
3
手机界面设计尺寸规范
4
小程序-记牌器
5
微信小程序app.json文件常用配置说明
6
微信小程序获得session_key和openId(加解密、签名系列)
7
微信小程序|实现界面滑动切换
8
小程序登录的最优流程
9
微信小程序尺寸单位rpx和样式使用详解
10
微信小程序-scroll-view滚动到指定位置(类似锚点)
1
微信小程序app.json文件常用配置说明
2
微信小程序文字控制单行超过显示省略号
3
微信小程序参数传递的几种方法
4
微信小程序使用button按钮分享
5
微信小程序的setData
6
小程序分享,获取openid
7
微信小程序-实现tab
8
微信开发者工具新建和导入小程序
9
微信小程序实现点击拍照长按录像功能
10
微信小程序必知知识
产品
商业授权
开通会员
易优代理
推荐主机
服务
更新日志
用户案例
加入Q群
增值服务
帮助
易优问答
标签手册
易优技巧
功能字典
关于
关于易优
知识产权
版权声明
隐私协议
工作日 8:30-12:00 14:30-18:00
周六及部分节假日提供值班服务
联系我们
QQ在线咨询
业务客服
付费修改
加入Q群
微信客服
工作日 8:30-12:00 14:30-18:30