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>
相关推荐
好好的哦2 小时前
uni-app小程序登录后…
小程序·uni-app
!win !15 小时前
uni-app小程序登录后…
前端·uni-app
aklry19 小时前
uniapp实现在线pdf预览以及下载
前端·pdf·uni-app
繁依Fanyi19 小时前
我的 PDF 工具箱:CodeBuddy 打造 PDFMagician 的全过程记录
java·pdf·uni-app·生活·harmonyos·codebuddy首席试玩官
陌路物是人非21 小时前
uniapp取消浏览自动填充
java·服务器·uni-app
lqj_本人1 天前
鸿蒙OS&UniApp实现视频播放与流畅加载:打造完美的移动端视频体验#三方框架 #Uniapp
uni-app·音视频·harmonyos
lqj_本人1 天前
鸿蒙OS&UniApp 实现一个精致的日历组件#三方框架 #Uniapp
uni-app·harmonyos
bysjlwdx1 天前
uniapp婚纱预约小程序
小程序·uni-app
骑450的皮卡丘1 天前
uniapp设置 overflow:auto;右边不显示滚动条的问题
css·uni-app·css3
lqj_本人1 天前
鸿蒙OS&UniApp实现个性化的搜索框与搜索历史记录#三方框架 #Uniapp
华为·uni-app·harmonyos