Vue移动端下拉加载更多数据onload实现方法浅析

 更新时间:2023年02月15日 15:04:59   作者:搬砖IT员  
这篇文章主要介绍了Vue移动端下拉加载更多数据onload实现方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

思想:van-list组件负责UI层监测触底, 执行onload函数, page++, 请求下页数据, 和现在数据合并显示更多, 设置loading为false, 确保下次触底还能执行onLoad

vant是一个可用于移动端的组件库,搭建页面框架,需要使用到vant组件,添加依赖yarn add vant@2.12.15至vue2项目内,此处用到van-list组件。

vant中的组件van-list来动态渲染数据,下拉加载首先需要绑定变量loading(加载状态)、属性finished(是否全部加载完成),finished-text全部加载完成显示的文字

 <van-list
     v-model="loading"
     :finished="finished"
     finished-text="没有更多了"
     @load="onLoad"
  >
       正常的遍历searchResult内数据 渲染至页面内容
 </van-list>      

数据:注意要有当前页页码page配合实现

data() {
    return {
      searchResult: [],  //搜索到的总的数据,用此数组内数据来遍历展示
      loading: false,  //加载中 (状态) - 只有为false, 才能触底后自动触发onload方法
      finished: false,   // 未加载全部 (如果设置为true, 底部就不会再次执行onload, 代表全部加载完成)
      page: 1,  // 当前搜索结果的页码
    };
  },  

以上为准备的数据,

onload 下拉刷新加载更多数据 (触底后加载下一页数据)

思想:

1、监测页面触底执行onload事件 (onload事件:页面内所有元素包括图片等都加载完成后执行)

2、配合后台接口,传递下一页的标识

3、拿到下一页数据后追加到当前数组末尾即可

<script>
export default {
  methods: {
    // 此为js代码,监听事件,发送异步操作的数据请求
    async btn2() {
      this.loading = false // 优化bug,防止出现首次多加载一次的情况
      this.finished = false // 加载未结束
      this.page = 1 // 走完函数,就将当前页恢复至1,防止后面累加,导致点击别的筛选条件时无效
      // 异步发送请求获取数据赋值给data内变量
      const { data } = await getSearchResult({
        keywords: this.value, // 此为接口需要的参数
        limit: 20
      })
      this.searchResult = data.result.songs
    },
    async onLoad() { // 触底事件(要加载下一页的数据), 内部会自动把loading改为true,为true后才会执行x
      this.page++ // 加载至底部就将页面值+1
      const { data } = await getSearchResult({
        keywords: this.value,
        limit: 20,
        offset: (this.page - 1) * 20 // 传参固定公式,页面偏移量即一页多少数据
      })
      if (data.result.songs === undefined) { // 下拉刷新后此次检索不到数据了,表示已经将所有数据加载完了
        return (this.finished = true) // finished赋值为true,表示 不再去进行加载了,结束状态
      }
      this.searchResult.push(...data.result.songs) // 将每次下拉刷新检索到的数据加入 展示的数据列表
      this.loading = false // 切记,本次加载完更多数据后,一定要把loading改成false, 保证下一次还能触发onload方法
    }
  }
}
</script>
 

第一次发送getSearchResult数据请求为加载第一页数据,限制获取数据数量limit为20条,第二次getSearchResult则是下拉到底,再去获取20条数据,再添加到第一次保存数据的数组里,这样就有40条数据同时渲染在了页面上,以后每下拉一次,就是此种操作,从请求里获取不到数据了,将finished赋值为true下拉加载事件就会停止

到此这篇关于Vue移动端下拉加载更多数据onload实现方法浅析的文章就介绍到这了,更多相关Vue下拉加载 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue3中引入SCSS和LESS依赖的基本步骤和注意事项

    Vue3中引入SCSS和LESS依赖的基本步骤和注意事项

    我们项目开发中经常遇到样式里面会使用less和scss写法, less,scss和stylus都是css的预处理器,这篇文章主要给大家介绍了关于Vue3中引入SCSS和LESS依赖的基本步骤和注意事项,需要的朋友可以参考下
    2024-05-05
  • 深入探索VueJS Scoped CSS 实现原理

    深入探索VueJS Scoped CSS 实现原理

    这篇文章主要介绍了深入探索VueJS Scoped CSS 实现原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • 如何用Vite构建工具快速创建Vue项目

    如何用Vite构建工具快速创建Vue项目

    Vite是一个web开发构建工具,由于其原生 ES 模块导入方法,它允许快速提供代码,下面这篇文章主要给大家介绍了关于如何用Vite构建工具快速创建Vue项目的相关资料,需要的朋友可以参考下
    2022-05-05
  • vue引用外部JS的两种种方法

    vue引用外部JS的两种种方法

    这篇文章主要介绍了vue引用外部JS的两种种方案,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-01-01
  • Vue.js列表渲染绑定jQuery插件的正确姿势

    Vue.js列表渲染绑定jQuery插件的正确姿势

    这篇文章主要为大家详细介绍了Vue.js列表渲染绑定jQuery插件的正确姿势,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • vue文件代码缩进以及格式化代码方式[自定义]

    vue文件代码缩进以及格式化代码方式[自定义]

    这篇文章主要介绍了vue文件代码缩进以及格式化代码方式[自定义],具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • Vue3+Vue Router实现动态路由导航的示例代码

    Vue3+Vue Router实现动态路由导航的示例代码

    随着单页面应用程序(SPA)的日益流行,前端开发逐渐向复杂且交互性强的方向发展,在这个过程中,Vue.js及其生态圈的工具(如Vue Router)为我们提供了强大的支持,本文将介绍如何在Vue 3中使用Vue Router实现动态路由导航,需要的朋友可以参考下
    2024-08-08
  • Vue中动态class的多种写法

    Vue中动态class的多种写法

    这篇文章主要介绍了Vue之动态class的几种写法,本文结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-12-12
  • 浅谈Vuejs Prop基本用法

    浅谈Vuejs Prop基本用法

    本篇文章主要介绍了Vuejs Prop基本用法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • vue 子组件修改data或调用操作

    vue 子组件修改data或调用操作

    这篇文章主要介绍了vue 子组件修改data或调用操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08

最新评论