uniapp实战 —— 可滚动区域 scroll-view (自适配高度,下拉刷新)

自适配高度

自定义的顶部导航栏,可参考博文
https://blog.csdn.net/weixin_41192489/article/details/134852124

如图可见,在页面滚动过程中,顶部导航栏和底栏未动,仅中间的内容区域可滚动。

  • 整个页面的高度设置为 100%,并采用 flex 布局
  • 滚动区域的高度,通过flex布局的flex-grow实现自适配
html 复制代码
<template>
  <!-- 顶部--自定义的导航栏 -->
  <CustomNavbar />
  <!-- 中间--自适配高度的滚动区 -->
  <scroll-view scroll-y class="contentBox">
  <!-- 此处省略了页面内容的相关代码 -->
  </scroll-view>
</template>
html 复制代码
<style lang="scss">
page {
  background-color: #f7f7f7;
  // 总容器高度撑满屏幕
  height: 100%;
  // 使容器内元素使用flex布局
  display: flex;
  flex-direction: column;
}
.contentBox {
  // 滚动区自适配高度
  flex-grow: 1;
}
</style>
  • 注意事项:此处样式不能加 scoped

下拉刷新

在 scroll-view 标签上新增

js 复制代码
    refresher-enabled
    @refresherrefresh="onRefresherrefresh"
    :refresher-triggered="isTriggered"

js中新增

js 复制代码
// 控制下拉刷新动画的显隐
const isTriggered = ref(false)
// 自定义下拉刷新被触发
const onRefresherrefresh = async () => {
  // 开启下拉刷新动画
  isTriggered.value = true
  // 重置子组件(猜你喜欢)分页相关数据(页码重置为1,清空列表,结束标记重置为false)
  guessRef.value?.resetData()
  // 加载数据--所有接口同时开始刷新,直到耗时最长的接口返回数据
  await Promise.all([getSwiperInfo(), getCategoryInfo(), guessRef.value?.getGuessList()])
  // 关闭下拉刷新动画
  isTriggered.value = false
}
相关推荐
1登峰造极13 小时前
uniapp 运行安卓报错reportJSException >>>> exception function:createInstanceContext, exception:white screen
android·java·uni-app
ヤ鬧鬧o.13 小时前
多彩背景切换演示
前端·css·html·html5
这儿有一堆花16 小时前
CSS 拟真光影设计:从扁平到深度的技术复盘
前端·css
_OP_CHEN16 小时前
【前端开发之CSS】(三)CSS 常用元素属性宝典(上):从字体到文本,手把手教你打造高颜值网页!
前端·css·html·网页开发·文本属性·字体属性·页面美化
滴水未满17 小时前
uniapp的组件
uni-app
object not found19 小时前
基于uniapp开发小程序自定义顶部导航栏状态栏标题栏
前端·javascript·小程序·uni-app
总爱写点小BUG21 小时前
VU-Icons:打造极致体验的 Vue3 & UniApp 双端 SVG 图标库
uni-app·vue·组件库·图标组件库
朝阳3921 小时前
CSS-in-JS(含样式化组件 styled-components)
css
咸虾米_21 小时前
uniapp引入iconfont字体图标在微信小程序中适用
微信小程序·小程序·uni-app
ヤ鬧鬧o.21 小时前
HTML多倒计时管理
前端·javascript·css·html5