​Electron-Vite + Vue 3​ 项目中实现流畅触底加载更多功能

 更新时间:2025年07月31日 11:38:05   作者:韶鹿先生  
本文介绍在Electron-Vite+Vue3项目中实现触底加载的两种方式:原生滚动监听和vue-infinite-loading库,下面给大家分享详细实现步骤,感兴趣的朋友一起看看吧

在 ​Electron-Vite + Vue 3​ 项目中实现触底加载更多(无限滚动)功能,可以通过监听滚动事件或使用现成的库(如 vue-infinite-loading)来完成。以下是详细实现步骤:

​方案一:原生滚动监听(推荐)​​

​1. 模板部分​

在需要触底加载的列表组件中,添加滚动监听:

<template>
  <div class="scroll-container" @scroll="handleScroll">
    <div v-for="item in items" :key="item.id">{{ item.content }}</div>
    <div v-if="loading" class="loading">加载中...</div>
    <div v-if="noMore" class="no-more">没有更多了</div>
  </div>
</template>

​2. 脚本部分​

<script setup>
import { ref, onMounted, onUnmounted } from 'vue';
const items = ref([]); // 数据列表
const page = ref(1);   // 当前页码
const loading = ref(false);
const noMore = ref(false);
// 模拟异步加载数据
const loadMore = async () => {
  if (loading.value || noMore.value) return;
  loading.value = true;
  try {
    // 替换为实际API请求
    const newItems = await fetchData(page.value);
    if (newItems.length === 0) {
      noMore.value = true;
    } else {
      items.value = [...items.value, ...newItems];
      page.value++;
    }
  } finally {
    loading.value = false;
  }
};
// 监听滚动事件
const handleScroll = (e) => {
  const { scrollTop, scrollHeight, clientHeight } = e.target;
  // 触底条件:距离底部 < 50px
  if (scrollHeight - (scrollTop + clientHeight) < 50) {
    loadMore();
  }
};
// 初始化加载
onMounted(() => {
  loadMore();
});
// 清理事件(如果绑定在window上)
onUnmounted(() => {
  window.removeEventListener('scroll', handleScroll);
});
</script>

​3. 样式部分​

<style scoped>
.scroll-container {
  height: 80vh; /* 固定高度触发滚动 */
  overflow-y: auto;
}
.loading, .no-more {
  text-align: center;
  padding: 10px;
}
</style>

​方案二:使用vue-infinite-loading库​

​1. 安装依赖​

npm install vue-infinite-loading@next

​2. 在组件中使用​

<template>
  <div>
    <div v-for="item in items" :key="item.id">{{ item.content }}</div>
    <InfiniteLoading @infinite="loadMore" :distance="100">
      <template #spinner>加载中...</template>
      <template #no-more>没有更多了</template>
    </InfiniteLoading>
  </div>
</template>
<script setup>
import { ref } from 'vue';
import InfiniteLoading from 'vue-infinite-loading';
const items = ref([]);
const page = ref(1);
const noMore = ref(false);
const loadMore = async ($state) => {
  try {
    const newItems = await fetchData(page.value);
    if (newItems.length === 0) {
      noMore.value = true;
      $state.complete();
    } else {
      items.value.push(...newItems);
      page.value++;
      $state.loaded();
    }
  } catch (err) {
    $state.error();
  }
};
</script>

​关键细节说明​

  • 触底条件计算
    • scrollHeight:内容总高度
    • scrollTop:已滚动高度
    • clientHeight:容器可视高度
    • 公式:scrollHeight - (scrollTop + clientHeight) < threshold
  • Electron 特殊处理
  • 如果内容在 <webview><iframe> 中,需在 ​主进程​ 中允许加载外部资源:
new BrowserWindow({
  webPreferences: {
    webSecurity: false // 允许跨域请求(开发环境)
  }
});
  • 性能优化
  • 使用 ​防抖​(lodash.debounce)避免频繁触发:
import { debounce } from 'lodash-es';
const handleScroll = debounce((e) => { ... }, 200);

​完整示例项目结构​

electron-vite-vue3-project/
├── src/
│   ├── main/           # Electron 主进程代码
│   ├── renderer/       # Vue 渲染进程代码
│   │   └── components/
│   │       └── InfiniteScroll.vue  # 触底加载组件
│   └── preload.js
└── vite.config.js

​常见问题​

  • Q:滚动事件不触发?​
    A:确保容器有固定高度和 overflow-y: auto
  • Q:数据重复加载?​
    A:检查 loadingnoMore 的状态锁。
  • Q:Electron 中跨域请求失败?​
    A:在主进程配置 webSecurity: false(仅限开发环境)。

通过以上方法,可以轻松在 Electron-Vite + Vue 3 中实现流畅的触底加载效果!

到此这篇关于​Electron-Vite + Vue 3​ 项目中实现触底加载更多的文章就介绍到这了,更多相关vue触底加载更多内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vuex实现数据持久化的两种方案

    vuex实现数据持久化的两种方案

    这两天在做vue项目存储个人信息的时候,遇到了页面刷新后个人信息数据丢失的问题,在查阅资料后,我得出两种解决数据丢失,使用数据持久化的方法,感兴趣的小伙伴跟着小编一起来看看吧
    2023-08-08
  • Vue项目打包编译优化方案

    Vue项目打包编译优化方案

    当一个较复杂的vue项目打包后,文件会非常大,而且访问时资源加载速度很慢,本文介绍了几种措施来优化。
    2020-09-09
  • vue+iview分页组件的封装

    vue+iview分页组件的封装

    这篇文章主要为大家详细介绍了vue+iview分页组件的封装,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • vue3使用element ui的方法实例

    vue3使用element ui的方法实例

    vue3出来好一段时间了,一直想着用一下,下面这篇文章主要给大家介绍了关于vue3使用element ui的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-10-10
  • vue+elementUI显示表格指定列合计数据方式

    vue+elementUI显示表格指定列合计数据方式

    这篇文章主要介绍了vue+elementUI显示表格指定列合计数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • Vue3中的组合式 API示例详解

    Vue3中的组合式 API示例详解

    组合式 API 是一系列 API 的集合,使我们可以使用函数而不是声明选项的方式书写 Vue 组件,这篇文章主要介绍了什么是Vue3的组合式 API,需要的朋友可以参考下
    2022-06-06
  • vuex新手进阶篇之actions的使用方法

    vuex新手进阶篇之actions的使用方法

    actions用来处理mutations中的异步操作,触发mutations中的函数,下面这篇文章主要给大家介绍了关于vuex新手进阶篇之actions的使用方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-10-10
  • 关于uniapp的高级表单组件mosowe-form

    关于uniapp的高级表单组件mosowe-form

    这篇文章主要介绍了关于uniapp的高级表单组件mosowe-form,由于一些表单标签改来改去比较繁琐,重复性很多,且样式布局啥的几乎万变不离其中,为了偷懒,开发了mosowe-form及mosowe-table两款高级组件,需要的朋友可以参考下
    2023-04-04
  • keep-alive不能缓存多层级路由菜单问题解决

    keep-alive不能缓存多层级路由菜单问题解决

    这篇文章主要介绍了keep-alive不能缓存多层级路由菜单问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • Vue解决element-ui消息提示$message重叠问题

    Vue解决element-ui消息提示$message重叠问题

    这篇文章主要为大家介绍了Vue解决element-ui消息提示$message重叠问题,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08

最新评论