vant4的van-pull-refresh里的列表不在顶部时下拉也会触发刷新的问题

官方的案例给人误导

html 复制代码
<van-pull-refresh v-model="loading" @refresh="onRefresh"> 
<p>刷新次数: {{ count }}</p> 
</van-pull-refresh>

这种结构,不管里面列表会不会滚动,只要下拉一定会触发下拉刷新

文档尾部给的说明

PullRefresh 的触发条件是?

PullRefresh 的触发条件是「父级滚动元素的滚动条在顶部位置」。

  • 如果最近一个可滚动的父级元素是 window,则要求 window.pageYOffset === 0
  • 如果最近一个可滚动的父级元素是 Element,则要求 Element.scrollTop === 0

基于此的改造方案

  • van-pull-refresh高度不控制,由内部列表撑开。(可以设置最小高度为列表容器高度)
  • van-pull-refresh外部负责控制滚动
html 复制代码
<div class="list-container" >
     <van-pull-refresh
       v-model="loading"
       style="min-height: 100%"
       @refresh="getAccountList"
     >
       <div
         class="account-item"
         v-for="account in accountList"
         :key="account.id"
       >
         <el-avatar
           :size="25"
           :src="account.imgUrl"
         >
           <img src="@/assets/avatar.png" />
         </el-avatar>
         <div class="account-name">{{ account.name }}</div>
       </div>
     </van-pull-refresh>
</div>
<style>
   .list-container {
      height: 100%;
      overflow-y: auto;
      .account-item {
        display: flex;
        align-items: center;
        column-gap: 10px;
        + .account-item {
          margin-top: 15px;
        }
        .account-name {
          word-break: break-all;
        }
      }
    }
</style>

常见的复杂的改造方案

  • 给van-pull-refresh增加disabled属性
  • van-pull-refresh里面包裹的滚动列表增加scroll监听,滚动到顶部之前,disabled一直为true
相关推荐
Hoshizola7 分钟前
uniapp与蓝牙设备连接详细步骤
前端·uni-app
优雅格子衫12 分钟前
uniapp 拍照相册选取后超级好用的裁剪组件,增加水印完全自定义
开发语言·前端·javascript·uni-app·vue
Dxy123931021616 分钟前
HTML如何写鼠标事件
前端·html·计算机外设
AI砖家29 分钟前
前端 JavaScript 异步处理全方案详解:从回调到 Observable
开发语言·前端·javascript
用户7138742290034 分钟前
构建现代 Web 应用的令牌安全体系:Refresh Token Rotation、HttpOnly Cookie 与 Grace Period 全解析
前端
之歆1 小时前
Day21_电商详情页核心技术实战:从LESS预处理到复杂交互实现
开发语言·前端·javascript·css·交互·less
海鸥两三1 小时前
基于 Vue 3 + 高德地图的网格规划系统实战(有源码)
前端·javascript·vue.js
丷丩1 小时前
MapLibre GL JS第11课:获取鼠标指针坐标
前端·javascript·gis·地图·mapbox·maplibre gl js
代码AI弗森1 小时前
前端周刊第 467 期[特殊字符] 本期精选目录
前端
随便的名字1 小时前
前端路由的底层逻辑:URL 中 # 和 ? 的区别与关系详解
前端