使用说明:
1. 任何容器都可以使用flex布局
display: flex
2.行内元素可以使用flex布局
display: inline-flex
外层flex容器的属性:
1.flex-direction属性
flex-direction: row | row-reverse | column | column-reverse
row(默认值):主轴为水平方向,起点在左端。
row-reverse:主轴为水平方向,起点在右端。
column:主轴为垂直方向,起点在上沿。
column-reverse:主轴为垂直方向,起点在下沿。
2.flex-wrap属性
flex-wrap: nowrap | wrap | wrap-reverse
nowrap (默认值) :不换行。
wrap:换行,第一行在上方。
wrap-reverse:换行,第一行在下方。
3. flex-flow属性:是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap
flex-flow: <flex-direction>|| <flex-wrap>
4. justify-content属性:定义item在主轴上的对齐方式
justify-content: flex-start | flex-end | center | space-between | space-around
flex-start(默认值):左对派帆齐
flex-end:右对齐
center: 居中
space-between:两端对模羡镇齐,项目之间的间隔都相等。
space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。
5. align-items属性:定义项目在交叉轴上如何对齐
align-items: flex-start | flex-end | center | baseline | stretch
flex-start:交叉轴的起点对齐。
flex-end:交叉轴的终点对齐。
center:交叉轴的中点对齐。
baseline: 项目的第一行文字的基线对齐。
stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。
6. align-content属性:定义多跟轴线的对齐方式,如果只有一根轴线则不起作用
align-content: flex-start | flex-end | center | space-between | space-around | stretch
flex-start:与交叉轴的起点对齐。
flex-end:与交叉轴的终点对齐。
center:与交叉轴的中点对齐。
space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。
space-around:每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。
stretch(默认值):轴线占满整个交叉轴。
项目item的属性
1. order属性:定义项目的排列顺序,数值越小越靠前,默认值为0,负数在0前面
order: <integer>
2. flex-grow属性:定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大
flex-grow: <number>/* default 0 */
3. flex-shrink属性:定义项目缩小比例,默认是1,即如果空间不足,该item将缩小
flex-shrink: <number>/* default 1 */
4. flex-basis属性:在分配多余空间之前,item占据的主轴空间(main size),默认值auto,即item本身大小
flex-basis: <length>| auto/* default auto */
5. flex属性:是flex-grow,flex-shrink,flex-basis的简写,默认值为0 1 auto,后面两个属性可选
flex: none | [ <'flex-grow'><'flex-shrink'>? || <'flex-basis'>]
该属性有两个快捷值:auto (1 1 auto) 和 none (0 0 auto)。
建议优先使用这个属性,而不是单独写三个分离的属性,因为浏览器会推算相关值。
6. align-self属性:允许单个item与其他item有不一样的对其方式,可覆盖align-items属性
align-self: auto | flex-start | flex-end | center | baseline | stretch
<blockquote><p>目前小程序已在前端占了一席之地,最近公司项目上用的就是小程序开发,由于功能及页面不是很多,所以直接原生开发,毕竟坑可能会少点,在开发过程中,小程序自带导航栏和客户的设计稿导航栏排在一起,感觉很别扭,因此要求去掉枣孝漏微信的自带导航栏,微信提供了这方面的api,接下来我们就实 *** 。</p></blockquote><div class="image-package"><img src="凳烂 https://upload-images.jianshu.io/upload_images/8877503-c85b39b2671d31b7.jpeg " img-data="{"format":"jpeg","size":14897,"height":141,"width":963}" class="uploaded-img" style="min-height:200pxmin-width:200px" width="auto" height="auto"/></div><p><span style="font-size:15px">这是小程序官方文档截图,可以看到导航栏样式支持两种,默认是带导航栏,另外一种是自定义导航栏-custom,如果使用自定义导航栏,我们可以</span></p><p><strong><span style="font-size:15px">全局配置</span></strong><span style="font-size:15px"/></p><span style="font-size:inherit">//app.json</span>
<span style="font-size:inherit">"window"</span>: {
<span style="font-size:inherit">"navigationStyle"</span>: <span style="font-size:inherit">"custom"</span>
}
<p><strong><span style="font-size:15px">单页面配置</span></strong></p><span style="font-size:inherit">//page.json</span>
{
<span style="font-size:inherit">"navigationStyle"</span>: <span style="font-size:inherit">"custom"</span>
}
<p><strong><span style="font-size:15px">效果对比</span></strong>
</p><div class="image-package"><img src=" https://upload-images.jianshu.io/upload_images/8877503-1d120c002c6ef37c.jpeg " img-data="{"format":"jpeg","size":17446,"height":352,"width":922}" class="uploaded-img" style="min-height:200pxmin-width:200px" width="auto" height="auto"/>
</div><span style="font-size:15px">能明显的看出来,自定义导航栏页面内容已经顶到屏幕顶端,除了胶囊按钮,其他都是页面可控区域。</span><span style="font-size:15px">每个手机的屏幕都不一样,各家系统的状态栏高度也不一样,因此,慎野我们在开发页面时要考虑屏幕的适配,有刘海的,要留出刘海的距离,没有的,要把状态栏高度留出来。</span><p><strong><span style="font-size:16px">1.获取导航栏高度及按钮位置</span></strong>
</p><p><span style="font-size:15px">微信提供了获取导航栏高度的Api和胶囊按钮位置的Api</span>
</p><span style="font-size:inherit">// 系统信息</span>
<span style="font-size:inherit">const</span>systemInfo = wx.getSystemInfoSync()
<span style="font-size:inherit">// 胶囊按钮位置信息</span>
<span style="font-size:inherit">const</span>menuButtonInfo = wx.getMenuButtonBoundingClientRect()
<p><span style="font-size:15px">在控制台打印出这两个Api返回结果</span></p><div class="image-package"><img src=" https://upload-images.jianshu.io/upload_images/8877503-7925dd39fb0ec47a.jpeg " img-data="{"format":"jpeg","size":39744,"height":497,"width":679}" class="uploaded-img" style="min-height:200pxmin-width:200px" width="auto" height="auto"/>
</div><p><span style="font-size:15px">这里面我们只说几个我们接下来用到的参数。</span></p>statusBarHeight <span style="font-size:inherit">// 状态栏高度</span>
screenWidth <span style="font-size:inherit">// 胶囊的宽度</span>
top <span style="font-size:inherit">// 胶囊到顶部距离</span>
height <span style="font-size:inherit">// 胶囊的高度</span>
right <span style="font-size:inherit">// 胶囊距离右边的距离</span>
<p><span style="font-size:15px">通过这几个参数,我们可以计算出状态栏的高度,微信胶囊所占的高度(存在padding值,可以使元素和胶囊纵向居中)</span>
</p><p><span style="font-size:15px">首先在app.js中定义全局data-globalData</span></p>globalData: {
navBarHeight: <span style="font-size:inherit">0</span>, <span style="font-size:inherit">// 导航栏高度</span>
menuBotton: <span style="font-size:inherit">0</span>, <span style="font-size:inherit">// 胶囊距底部间距(保持底部间距一致)</span>
menuRight: <span style="font-size:inherit">0</span>,<span style="font-size:inherit">// 胶囊距右方间距(方保持左、右间距一致)</span>
menuHeight: <span style="font-size:inherit">0</span>, <span style="font-size:inherit">// 胶囊高度(自定义内容可与胶囊高度保证一致)</span>
},
<p><span style="font-size:15px">新建个方法</span>
</p>setNavBarInfo() {
<span style="font-size:inherit">// 获取系统信息</span>
const systemInfo = wx.getSystemInfoSync()
<span style="font-size:inherit">// 胶囊按钮位置信息</span>
const menuButtonInfo = wx.getMenuButtonBoundingClientRect()
<span style="font-size:inherit">// 导航栏高度 = 状态栏到胶囊的间距(胶囊距上距离-状态栏高度) * 2 + 胶囊高度 + 状态栏高度</span>
<span style="font-size:inherit">this</span>.globalData.navBarHeight = (menuButtonInfo.top - systemInfo.statusBarHeight) * <span style="font-size:inherit">2</span>+ menuButtonInfo.height + systemInfo.statusBarHeight
<span style="font-size:inherit">this</span>.globalData.menuBotton = menuButtonInfo.top - systemInfo.statusBarHeight
<span style="font-size:inherit">this</span>.globalData.menuRight = systemInfo.screenWidth - menuButtonInfo.right
<span style="font-size:inherit">this</span>.globalData.menuHeight = menuButtonInfo.right
}
<p><span style="font-size:15px">在onLaunch中调用,因为我这个项目是所有的导航都不用微信自带的,所以在app.js</span>
</p><p><span style="font-size:15px">中调用及设置data。</span></p>onLaunch() {
<span style="font-size:inherit">this</span>.setNavBarInfo()
},
<p><span style="font-size:15px"/><span style="font-size:15px">到这里所需要用到的都已经存了起来,页面用法也比较简单,排除状态栏的高度,设置导航栏的高度和胶囊高度保持,用flex布局。</span>
</p><p><strong><span style="font-size:16px">2.页面适配</span></strong></p><p><span style="font-size:15px">首先page.js中定义变量</span></p><span style="font-size:inherit">var</span>app = getApp()
Page({
<span style="font-size:inherit">/*
* 页面的初始数据
/</span>
data: {
navBarHeight: app.globalData.navBarHeight, <span style="font-size:inherit">//导航栏高度</span>
menuBotton: app.globalData.menuBotton, <span style="font-size:inherit">//导航栏距离顶部距离</span>
menuRight: app.globalData.menuRight, <span style="font-size:inherit">//导航栏距离右侧距离</span>
menuHeight: app.globalData.menuHeight, <span style="font-size:inherit">//导航栏高度</span>
}
})
<p><span style="font-size:15px">页面使用</span>
</p><span style="font-size:inherit"><<span style="font-size:inherit">view</span><span style="font-size:inherit">class</span>=<span style="font-size:inherit">"nav"</span><span style="font-size:inherit">style</span>=<span style="font-size:inherit">"height:{{navBarHeight}}px"</span>></span>
<span style="font-size:inherit"><<span style="font-size:inherit">view</span><span style="font-size:inherit">class</span>=<span style="font-size:inherit">"nav-main"</span>></span>
<span style="font-size:inherit"></span>
<span style="font-size:inherit"><<span style="font-size:inherit">view</span>
<span style="font-size:inherit">class</span>=<span style="font-size:inherit">"capsule-box"</span> <span style="font-size:inherit">style</span>=<span style="font-size:inherit">"style="</span><span style="font-size:inherit">height:</span>{{menuHeight+menuBotton 2}}<span style="font-size:inherit">px</span><span style="font-size:inherit">min-height:</span>{{menuHeight}}<span style="font-size:inherit">px</span><span style="font-size:inherit">line-height:</span>{{menuHeight}}<span style="font-size:inherit">px</span><span style="font-size:inherit">bottom:0px</span><span style="font-size:inherit">padding:0</span>{{menuRight}}<span style="font-size:inherit">px</span>"></span>
<span style="font-size:inherit"></span>
<span style="font-size:inherit"><<span style="font-size:inherit">slot</span>></span><span style="font-size:inherit"></<span style="font-size:inherit">slot</span>></span>
<span style="font-size:inherit"></<span style="font-size:inherit">view</span>></span>
<span style="font-size:inherit"></<span style="font-size:inherit">view</span>></span>
<span style="font-size:inherit"></<span style="font-size:inherit">view</span>></span>
<p><span style="font-size:15px">wxss</span>
</p><span style="font-size:inherit">/ 公共导航 */</span>
<span style="font-size:inherit">.nav</span>{
<span style="font-size:inherit">position</span>: fixed
<span style="font-size:inherit">top</span>: <span style="font-size:inherit">0</span>
<span style="font-size:inherit">left</span>: <span style="font-size:inherit">0</span>
<span style="font-size:inherit">box-sizing</span>: border-box
<span style="font-size:inherit">width</span>: <span style="font-size:inherit">100vw</span>
<span style="font-size:inherit">z-index</span>: <span style="font-size:inherit">1000</span>
}
<span style="font-size:inherit">.nav-main</span>{
<span style="font-size:inherit">width</span>: <span style="font-size:inherit">100%</span>
<span style="font-size:inherit">height</span>: <span style="font-size:inherit">100%</span>
<span style="font-size:inherit">box-sizing</span>: border-box
<span style="font-size:inherit">position</span>: relative
}
<span style="font-size:inherit">.nav</span><span style="font-size:inherit">.capsule-box</span>{
<span style="font-size:inherit">position</span>: absolute
<span style="font-size:inherit">box-sizing</span>: border-box
<span style="font-size:inherit">width</span>: <span style="font-size:inherit">100%</span>
<span style="font-size:inherit">display</span>: flex
<span style="font-size:inherit">align-items</span>: center
}
<p><span style="font-size:15px">最终效果</span></p><div class="image-package"><img src=" https://upload-images.jianshu.io/upload_images/8877503-ef017724a144e58c.jpeg " img-data="{"format":"jpeg","size":4933,"height":105,"width":349}" class="uploaded-img" style="min-height:200pxmin-width:200px" width="auto" height="auto"/>
</div><p><span style="font-size:15px"/>
</p><p><span style="font-size:15px">此种适配方案适应所有手机,应该说是最优的选择。</span></p>
浮动布局的优点就是比较简单,兼容性也比较好。缺点是浮动元素是脱离文档流,要做清除浮动,否则可能会出现高度塌陷等问题。高雹改
绝对定位布局优点: 很快捷,设置很方便.
但是脱离文档戚判流的, 可能会造成重叠元素
在flex布局不兼容的时候,可以尝试表格布局。
CSS基础(float属性与清肆昌除浮动)
三栏布局的5种解决方案及优缺点
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)