vant-List 列表-加载刷新-下拉刷新

dom 代码

javascript 复制代码
<van-pull-refresh v-model="refreshing" @refresh="onRefresh">
            <van-list
            v-model="loading"
            :finished="finished"
            finished-text="没有更多了"
            @load="onLoad"
            >
            <Messages :item-list="itemlist"></Messages>
            </van-list>
        </van-pull-refresh>

js 代码

javascript 复制代码
<script>
export default {
    data() {
        return {
            itemlist:[],
            page_index:1,
            loading:false, // 是否加载
            finished:false, // 是否加载完成
            refreshing:false, // 是否要下拉刷新
        }
    },
    components:{
        Messages
    },
    created() {
        this.getData()
    },
    methods:{
        /*下拉加载,定时为了体现加载间隔*/ 
        onLoad() {
            setTimeout(()=>{
                if(this.refreshing) this.refreshing = false
                this.getData()
            },500)
        },
        /*重新加载*/
        onRefresh() {
            this.finished = false;
            this.loading = true;
            this.page_index = 1
            this.onLoad();
        },
        /*获取数据*/ 
        async getData(){
            const data={
                page_index:this.page_index,
                page_size: 10
            }
            const res = await getMesageData(data)
            this.loading=false
            if(res.success){
                this.itemlist=[...this.itemlist,...res.data]
                this.page_index++
            }
            // 是否加载完成(注意:对比数据建议提供总页数
            this.finished=(res.page_index==res.total_pages)?true:false
        }
    },
}
</script>

按文档进行,基本无误

参考:vant

相关推荐
计算机毕业设计木哥6 分钟前
计算机毕业设计选题推荐:基于SpringBoot和Vue的快递物流仓库管理系统【源码+文档+调试】
java·vue.js·spring boot·后端·课程设计
Wx-bishekaifayuan1 小时前
基于微信小程序的社区图书共享平台设计与实现 计算机毕业设计源码44991
javascript·vue.js·windows·mysql·pycharm·tomcat·php
九十一3 小时前
vue3事件总线与emit
前端·vue.js
丨Sky丨夜吻3 小时前
vscode扩展
ide·vue.js·vscode
青灬河4 小时前
实现企业级全栈应用服务框架-Elpis(一)
vue.js·node.js
一只小风华~5 小时前
学习笔记:Vue Router 中的链接匹配机制与样式控制
前端·javascript·vue.js·笔记·学习·ecmascript
FuckPatience7 小时前
前端Vue 后端ASP.NET Core WebApi 本地调试交互过程
前端·vue.js·asp.net
北城以北88887 小时前
Vue-- Axios 交互(二)
javascript·vue.js·交互
我总是词不达意7 小时前
vue3 + el-upload组件集成阿里云视频点播从本地上传至点播存储
前端·vue.js·阿里云·elementui
北城以北88888 小时前
Vue-- Axios 交互(一)
前端·javascript·vue.js