uniapp uni-popup使用scroll-view滚动时,底部按钮设置position:fixed失效,部分ios设置有问题

uniapp uni-popup使用scroll-view滚动时,底部按钮设置position:fixed失效,部分ios设置有问题

尝试过多种办法,最后发现部分机型position:fixed失效,position: sticky可以用,但是只设置sticky的话,部分机型又会有问题,无法在最底部,所以想到了嵌套的方法。

FilterPopup.vue弹框组件

html 复制代码
<template>
  <!--设置page-meta,弹框打开时禁止滚动页面-->
  <page-meta :page-style="'overflow:'+(isShow?'hidden':'visible')"></page-meta>
  <!-- 筛选 -->
  <uni-popup ref="popupFilter" type="right" background-color="#fff" @change="popupChange">
    <scroll-view scroll-y="true" class="popup-content">
      <view class="main-cont">
        <slot/>
      </view>
      <view class="bottom-fixed-bg-cont-filter"></view>
      <!--给按钮的view再包一层view,设置sticky-->
      <view class="position-sticky" :class="tabBarFilter?'tabbar-btn':''">
        <view class="bottom-fixed-btn-cont">
          <button size="large" class="button" @click="handle('reset')">重置</button>
          <button size="large" class="button button-confirm" type="info" @click="handle('submit')">确认</button>
        </view>
      </view>
    </scroll-view>
  </uni-popup>
</template>
<script setup>
import {ref} from 'vue'

const props = defineProps({
  // 如果是带有tabBar页面的筛选项,tabBarFilter传true,查询重置按钮需要根据入参重设高度
  tabBarFilter: {
    type: Boolean || undefined,
    default: ''
  },
  customClose: { // 自行处理关闭
    type: Boolean,
    default: false
  }
})
const isShow = ref(false)
const emits = defineEmits(['submit', 'reset'])
const handle = (type) => {
  emits(type)
  if (props.customClose && type === 'submit') return;
  close()
}
const popupFilter = ref(null)

function open() {
  popupFilter.value.open()
}

function close() {
  popupFilter.value.close()
}

const popupChange = (e) => {
  isShow.value = e.show
}

defineExpose({
  open,
  close
})
</script>
<style scoped lang="scss">
.popup-content {
  width: 600rpx;
  height: 100vh;
  box-sizing: border-box;

  .main-cont {
    padding: 16rpx 54rpx 0 54rpx;
    box-sizing: border-box;
  }
}

.bottom-fixed-bg-cont-filter {
  // #ifdef H5
  height: 260rpx;
  // #endif
  // #ifndef H5
  height: 180rpx;
  // #endif
  padding-bottom: constant(safe-area-inset-bottom);
  padding-bottom: env(safe-area-inset-bottom);
}

.position-sticky {
  position: sticky;
}
.bottom-fixed-btn-cont {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 160rpx;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #ffffff;
  padding: 10rpx 20rpx;
  padding-bottom: constant(safe-area-inset-bottom);
  padding-bottom: env(safe-area-inset-bottom);
  box-shadow: rgba(0, 0, 0, 0.08) 0 0 3px 1px;
}

</style>
相关推荐
云起SAAS3 小时前
私域直播系统UniApp源码 多商户商城+直播带货 微信小程序+H5+安卓iOS
android·微信小程序·uni-app·私域直播系统
专科3年的修炼2 天前
uni-app移动应用开发第四章
开发语言·javascript·uni-app
q5507071772 天前
uniapp/uniappx实现原生图片编辑涂鸦、贴图、滤镜、旋转、裁剪等
uni-app
计算机学姐3 天前
基于微信小程序的校园失物招领管理系统【uniapp+springboot+vue】
java·vue.js·spring boot·mysql·信息可视化·微信小程序·uni-app
2501_915921433 天前
HTTPS前端劫持 新一代流量劫持解决方案
前端·网络协议·ios·小程序·https·uni-app·iphone
爱怪笑的小杰杰3 天前
优化 UniApp 日历组件的多语言切换:告别 setLocale 引起的 App 重启
java·前端·uni-app
计算机学姐3 天前
基于微信小程序的宠物服务系统【uniapp+springboot+vue】
java·vue.js·spring boot·mysql·微信小程序·uni-app·宠物
2501_915909063 天前
iOS应用签名的三种方法全解析:从官方到第三方工具
android·ios·小程序·https·uni-app·iphone·webview
心中无石马4 天前
uniapp引入tailwindcss4.x
前端·css·uni-app
fix一个write十个4 天前
【uniApp开发】微信小程序 web-view 内嵌 H5 跳转支付踩坑实录
微信小程序·uni-app