uni-app的scroll-view下拉刷新加载状态关闭不了的问题

举报
薛定喵君 发表于 2021/07/10 12:40:53 2021/07/10
【摘要】 最近使用uni-app开发h5时遇到下拉刷新状态无法关闭的问题,记录一下 需求场景页面是一个列表页顶部有一个搜索框,列表区域使用scroll-view组件自定义下拉刷新,通过refresher-triggered来控制加载状态的显示隐藏文档说明refresher-triggered用于设置当前下拉刷新状态:true 表示下拉刷新已经被触发false 表示下拉刷新未被触发@refresherp...

最近使用uni-app开发h5时遇到下拉刷新状态无法关闭的问题,记录一下

需求场景

页面是一个列表页顶部有一个搜索框,列表区域使用scroll-view组件自定义下拉刷新,通过refresher-triggered来控制加载状态的显示隐藏

文档说明
refresher-triggered用于设置当前下拉刷新状态:

  • true 表示下拉刷新已经被触发
  • false 表示下拉刷新未被触发

@refresherpulling用来定义自定义下拉刷新控件被下拉时触发的事件
@refresherrefresh用来定义自定义下拉刷新被触发执行的事件

然而发现在自定义下拉刷新执行事件中直接将refresher-triggered绑定的值改为false后并不会关闭加载状态。

解决办法
refresher-triggered的初始值为false
要先变为true,执行完刷新操作之后再变为false才会有效果,所以在自定义下拉刷新控件被下拉时触发的事件中将值置为true并加一些延时再变为false才有了效果。

页面代码示例:


<template>
    <scroll-view class="content" scroll-y
        refresher-enabled="true" :refresher-triggered="triggered"
        :refresher-threshold="60" refresher-background="#f0f2f6"
        @refresherpulling="onPulling"
        @refresherrefresh="onRefresh">
    </scroll-view>
</view>
</template>

<script>
export default {
    data() {
        return {
            triggered: false
        }
    },
    methods: {
        onPulling() {
            var that = this;
            if(!this.triggered){
                //下拉加载,先让其变true再变false才能关闭
                this.triggered = true; 
                //关闭加载状态 (转动的圈),需要一点延时才能关闭
                setTimeout(() => {
                    that.triggered = false;
                },1000)
            }
        },
        onRefresh() {
            // 自定义下拉刷新被触发执行
        }
    }
}
</script>

参考资料

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。