当前位置: 代码网 > it编程>前端脚本>Vue.js > vue实现商品列表的无限加载思路和步骤详解

vue实现商品列表的无限加载思路和步骤详解

2024年07月02日 Vue.js 我要评论
基础思路触底条件满足之后 page++,拉取下一页数据新老数据做数组拼接判断是否已经全部加载完毕,停止监听步骤1:加载下一页数据重构商品二级分类组件注:v-infinite-scroll为elemen

基础思路

  • 触底条件满足之后 page++,拉取下一页数据
  • 新老数据做数组拼接
  • 判断是否已经全部加载完毕,停止监听

步骤1:加载下一页数据

重构商品二级分类组件

注:v-infinite-scroll为elementplus中infinite scroll无限滚动的自定义指令

<div class="body" v-infinite-scroll="load" >
        <!-- 商品列表-->
        <goodsitem v-for="good in goodlist" :good="good" :key="good.id"></goodsitem>
</div>
//加载更多
const load = async () => {  
  // 获取下一页的数据
  reqdata.value.page++
  console.log(reqdata.value.page)
  const res = await getsubcategoryapi(reqdata.value)
  //新加载的数据与老数据进行拼接合并
  goodlist.value = [...goodlist.value, ...res.result.items]  
}
// 获取二级分类商品
const goodlist = ref([])
const reqdata = ref({
    categoryid: route.params.id,
    page: 1,
    pagesize: 20,
    sortfield: 'publishtime'
})
const getgoodlist = async () => {
    const res = await getsubcategoryapi(reqdata.value)
    goodlist.value = res.result.items
}
onmounted(() => getgoodlist())

步骤2:无数据停止加载

重构template与script,infinite-scroll-disabled也是infinite scroll的指令

<div class="body" v-infinite-scroll="load" :infinite-scroll-disabled="disabled">
        <!-- 商品列表-->
        <goodsitem v-for="good in goodlist" :good="good" :key="good.id"></goodsitem>
</div>

到此这篇关于vue实现商品列表的无限加载的文章就介绍到这了,更多相关vue商品列表无限加载内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com