微信小程序 页面除去头部和底部,中间高度铺满剩余部分的解决方案

本文介绍如何在微信小程序中实现页面除去头部和底部,中间内容区域高度自动铺满并支持滚动。关键在于使用`position: fixed`定位,并通过计算去除橙色固定部分后的高度,确保紫色部分的内容在内容超出时能正确滚动显示。
摘要由CSDN通过智能技术生成

做这么一个界面,让中间紫色和橙色部分的内容铺满在中间位置,并且让橙色部分位置固定不动,紫色部分内容超出时滚动,如图:

 首先如何做到呢?

我使用了定位position:fiexed;让它撑满(关键代码),

position: fixed;top: {
  {topHeight + 30}}rpx;left: 25rpx;right: 25rpx;bottom:30rpx;

 

然后通过计算出紫色部分的高度 = 紫橙外部view的高度 - 橙色部分的高度,当内容过长时滚动(滚动需要设置一个高度),并完全显示内容。

这么做的目地是如果紫色部分直接设置高度100%时,它里面的内容不会完全显示,因为紫色的高度是根据包含它的外部view的高度设置100%的,而外部的view里面还有一个橙色view的高度,会把紫色往下挤,所以会显示不完全,只能通过计算高度来显示全部的信息。

代码:

首先

app.json,在onLaunch里面设置我的头部导航的高度(我自定义的导航栏)

let that = this;
    //获取系统信息
    wx.getSystemInfo({
      success: res => {
        that.globalData.statusBarHeight = res.statusBarHeight;//获取状态栏的高度
        //设置导航栏高度,判断不同系统,设置不同高度
        if (res.platform == "ios") {
          that.globalData.navHeight = 44;
        }else if (res.platform == "android") {
          that.globalData.navHeight = 48;
        } else {
          that.globalData.navHeight = 44;
        }
      },
      fail(err) {
        console.log(err);
      }
    });

接下来,

main.wxml  ,我这里是自定义的头部导航组件,就不列出来了,如果不是自定义的,头部导航的高度还有状态栏怎么获取可以百度,我下面的js代码有获取节点高度的,剩下的靠你自己了,都有很简单(不是自定义的可以忽略我上面的代码,如果是系统自带的导航,获取高度去百

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值