van-list的使用

html 复制代码
<van-list
          v-if="joblist && joblist.length > 0"
          v-model:loading="loading"
          :finished="finished"
          :immediate-check="false"
          finished-text="没有更多了"
          @load="onLoad"
        >
js 复制代码
// 加载
const loading = ref(false);
// 全部加载完毕
const finished = ref(false);

// 加载更多触底事件
const onLoad = async () => {
  if (joblist.value.length < total.value) {
    searchform.value.pageNum++;
    await getjoblist();
    loading.value = false;
  } else {
    loading.value = false;
    finished.value = true;
  }
};

const getjoblist = async () => {
  const res = await queryJoblist(searchform.value);
  if (res.code === 200) {
    total.value = res.total;
    //使用concat将新数据和原来的列表拼接在一起,不能直接赋值
    joblist.value = joblist.value.concat(res.rows);
  }
};

注意!!!
要使用concat将新数据和原来的列表拼接在一起,不能直接赋值,否则每次请求后的页面高度都是在页面底部,导致一直触发onLoad方法请求接口多次

相关推荐
o***Z4485 分钟前
JavaScript在Node.js中的内存管理
开发语言·javascript·node.js
李游Leo17 分钟前
前端安全攻防指南:XSS / CSRF / 点击劫持与常见防护实践(含真实案例拆解)
前端·安全·xss
我命由我1234533 分钟前
微信开发者工具 - 模拟器分离窗口与关闭分离窗口
前端·javascript·学习·微信小程序·前端框架·html·js
E***q53937 分钟前
Vue增强现实开发
前端·vue.js·ar
S***428038 分钟前
JavaScript在Web中的Angular
前端·javascript·angular.js
4***14901 小时前
Vue代码规范详解
javascript·vue.js·代码规范
黑幕困兽1 小时前
ehcarts 实现 饼图扇区间隙+透明外描边
前端·echarts
San301 小时前
深入理解 JavaScript 词法作用域链:从代码到底层实现机制
前端·javascript·ecmascript 6
进击的野人1 小时前
深入理解 JavaScript Promise:原理、用法与实践
javascript·面试·ecmascript 6
七淮1 小时前
Next.js SEO 优化完整方案
前端·next.js