当前位置: 首页 > article >正文

【Vue3】Vue 3 中列表排序的优化技巧

在这里插入图片描述

本文将深入探讨 Vue 3 中列表排序的优化技巧,帮助提升应用的性能和响应速度。

1. 避免不必要的排序

按需排序

在实际应用中,并非每次数据更新都需要进行排序。例如,当列表数据仅在特定条件下需要排序时,可通过条件判断来避免不必要的排序操作。

<template><div><button @click="shouldSort = true">排序</button><ul><li v-for="item in sortedList" :key="item.id">{{ item.name }}</li></ul></div>
</template><script setup>
import { ref, computed } from 'vue';const list = ref([{ id: 1, name: 'Apple' },{ id: 2, name: 'Banana' },{ id: 3, name: 'Cherry' }
]);const shouldSort = ref(false);const sortedList = computed(() => {if (shouldSort.value) {return [...list.value].sort((a, b) => a.name.localeCompare(b.name));}return list.value;
});
</script>

防抖与节流

当排序操作与用户交互(如点击排序按钮)相关时,可使用防抖(Debounce)或节流(Throttle)技术来减少不必要的排序触发。以防抖为例,在用户频繁点击排序按钮时,只在最后一次点击后的一段时间后执行排序操作。

<template><div><button @click="debouncedSort">排序</button><ul><li v-for="item in sortedList" :key="item.id">{{ item.name }}</li></ul></div>
</template><script setup>
import { ref, computed } from 'vue';
import { debounce } from 'lodash';const list = ref([{ id: 1, name: 'Apple' },{ id: 2, name: 'Banana' },{ id: 3, name: 'Cherry' }
]);const sortedList = computed(() => {return [...list.value].sort((a, b) => a.name.localeCompare(b.name));
});const debouncedSort = debounce(() => {// 这里可以添加其他与排序相关的逻辑
}, 300);
</script>

2. 优化排序算法

选择合适的排序算法

JavaScript 数组的 sort() 方法默认使用的是不稳定的排序算法,在某些情况下可能无法满足需求。对于大型数据集,可考虑使用更高效的排序算法,如快速排序(Quick Sort)或归并排序(Merge Sort)。不过,由于 JavaScript 引擎对 sort() 方法进行了优化,在大多数情况下,直接使用 sort() 已经足够高效。

减少比较次数

在多字段排序时,可通过合理安排比较字段的顺序,减少不必要的比较次数。例如,优先比较区分度大的字段。

const sortedList = [...list].sort((a, b) => {if (a.category!== b.category) {return a.category.localeCompare(b.category);}return a.name.localeCompare(b.name);
});

3. 利用计算属性和缓存

计算属性的使用

在 Vue 3 中,计算属性(Computed Properties)会自动缓存结果,只有当依赖的数据发生变化时才会重新计算。因此,将排序逻辑封装在计算属性中可以避免不必要的重复计算。

<template><div><ul><li v-for="item in sortedList" :key="item.id">{{ item.name }}</li></ul></div>
</template><script setup>
import { ref, computed } from 'vue';const list = ref([{ id: 1, name: 'Apple' },{ id: 2, name: 'Banana' },{ id: 3, name: 'Cherry' }
]);const sortedList = computed(() => {return [...list.value].sort((a, b) => a.name.localeCompare(b.name));
});
</script>

手动缓存排序结果

在某些场景下,可手动缓存排序结果,避免重复排序。例如,当数据更新但排序条件未改变时,直接使用缓存的排序结果。

<template><div><button @click="updateData">更新数据</button><ul><li v-for="item in sortedList" :key="item.id">{{ item.name }}</li></ul></div>
</template><script setup>
import { ref, computed } from 'vue';const list = ref([{ id: 1, name: 'Apple' },{ id: 2, name: 'Banana' },{ id: 3, name: 'Cherry' }
]);let cachedSortedList = null;
let lastSortCondition = null;const sortedList = computed(() => {const currentSortCondition = 'name'; // 这里可以根据实际情况动态变化if (currentSortCondition === lastSortCondition && cachedSortedList) {return cachedSortedList;}cachedSortedList = [...list.value].sort((a, b) => a.name.localeCompare(b.name));lastSortCondition = currentSortCondition;return cachedSortedList;
});const updateData = () => {list.value = [{ id: 4, name: 'Date' },{ id: 5, name: 'Eggplant' }];
};
</script>

4. 虚拟列表与分页

虚拟列表

当列表数据量非常大时,一次性渲染所有数据会导致性能问题。虚拟列表(Virtual List)技术只渲染当前可见区域的数据,从而显著提升性能。在 Vue 3 中,可使用第三方库如 vue-virtual-scroller 来实现虚拟列表。

<template><div><VirtualList :items="list" :item-size="30"><template #item="{ item }"><div>{{ item.name }}</div></template></VirtualList></div>
</template><script setup>
import { ref } from 'vue';
import { VirtualList } from 'vue-virtual-scroller';
import 'vue-virtual-scroller/dist/vue-virtual-scroller.css';const list = ref([// 大量数据...
]);
</script>

分页

分页是另一种减少一次性渲染数据量的有效方法。通过将数据分成多个页面,每次只加载和渲染当前页面的数据。

<template><div><ul><li v-for="item in currentPageData" :key="item.id">{{ item.name }}</li></ul><button @click="prevPage" :disabled="currentPage === 1">上一页</button><button @click="nextPage" :disabled="currentPage === totalPages">下一页</button></div>
</template><script setup>
import { ref, computed } from 'vue';const list = ref([// 大量数据...
]);const itemsPerPage = 10;
const currentPage = ref(1);const totalPages = computed(() => {return Math.ceil(list.value.length / itemsPerPage);
});const currentPageData = computed(() => {const startIndex = (currentPage.value - 1) * itemsPerPage;const endIndex = startIndex + itemsPerPage;return list.value.slice(startIndex, endIndex);
});const prevPage = () => {if (currentPage.value > 1) {currentPage.value--;}
};const nextPage = () => {if (currentPage.value < totalPages.value) {currentPage.value++;}
};
</script>

总结

在 Vue 3 中进行列表排序时,通过避免不必要的排序、优化排序算法、利用计算属性和缓存以及采用虚拟列表与分页技术等优化技巧,可以显著提升应用的性能和用户体验。开发者应根据具体的业务场景和数据量大小,选择合适的优化策略。

相关文章:

【Vue3】Vue 3 中列表排序的优化技巧

本文将深入探讨 Vue 3 中列表排序的优化技巧&#xff0c;帮助提升应用的性能和响应速度。 1. 避免不必要的排序 按需排序 在实际应用中&#xff0c;并非每次数据更新都需要进行排序。例如&#xff0c;当列表数据仅在特定条件下需要排序时&#xff0c;可通过条件判断来避免不…...

【Github每日推荐】-- 2024 年项目汇总

1、AI 技术 项目简述OmniParser一款基于纯视觉的 GUI 智能体&#xff0c;能够准确识别界面上可交互图标以及理解截图中各元素语义&#xff0c;实现自动化界面交互场景&#xff0c;如自动化测试、自动化操作等。ChatTTS一款专门为对话场景设计的语音生成模型&#xff0c;主要用…...

在C#中动态访问对象属性时,用表达式树可以获得高效性能

在C#中如何用表达式树动态访问对象属性的问题。用户可能已经知道反射的基本用法&#xff0c;但想用表达式树来提高性能&#xff0c;因为表达式树编译后的委托执行速度比反射快。 首先&#xff0c;表达式树的基本概念。表达式树允许在运行时构建代码&#xff0c;并编译成可执行的…...

Nginx实战_高性能Web服务器与反向代理的配置全解

1. 引言 1.1 Nginx简介 Nginx(发音为 “engine-x”)是一款轻量级、高性能的HTTP服务器和反向代理服务器。它以其高并发处理能力和低资源消耗而闻名,广泛应用于互联网企业中。Nginx不仅可以作为静态文件服务器,还可以通过反向代理功能与后端应用服务器协同工作。 1.2 Ngi…...

使用html css js 来实现一个服装行业的企业站源码-静态网站模板

最近在练习 前端基础&#xff0c;html css 和js 为了加强 代码的 熟悉程序&#xff0c;就使用 前端 写了一个个服装行业的企业站。把使用的技术 和 页面效果分享给大家。 应用场景 该制衣服装工厂官网前端静态网站模板主要用于前端练习和编程练习&#xff0c;适合初学者进行 HT…...

Flutter 网络请求与数据处理:从基础到单例封装

Flutter 网络请求与数据处理&#xff1a;从基础到单例封装 在 Flutter 开发中&#xff0c;网络请求是一个非常常见的需求&#xff0c;比如获取 API 数据、上传文件、处理分页加载等。为了高效地处理网络请求和数据管理&#xff0c;我们需要选择合适的工具并进行合理的封装。 …...

数控机床设备分布式健康监测与智能维护系统MTAgent

数控机床设备分布式健康监测与智能维护系统MTAgent-v1.1融合了目前各种先进的信号处理以及信息分析算法以算法工具箱的方式&#xff0c;采用了一种开发的、模块化的结构实现信号各种分析处理&#xff0c;采用Python编程语言&#xff0c;满足不同平台需求(包括Windows、Linux)。…...

Java+SpringBoot+数据可视化的家庭记账小程序(程序+论文+安装+调试+售后等)

感兴趣的可以先收藏起来&#xff0c;还有大家在毕设选题&#xff0c;项目以及论文编写等相关问题都可以给我留言咨询&#xff0c;我会一一回复&#xff0c;希望帮助更多的人。 系统介绍 在当下这个科技日新月异、经济蓬勃向上的时代&#xff0c;中国经济正以令人瞩目的速度迅…...

基于 Ollama 工具的 LLM 大语言模型如何部署,以 DeepSeek 14B 本地部署为例

简简单单 Online zuozuo :本心、输入输出、结果 文章目录 基于 Ollama 工具的 LLM 大语言模型如何部署,以 DeepSeek 14B 本地部署为例前言下载 Ollama实际部署所需的硬件要求设置 LLM 使用 GPU ,发挥 100% GPU 性能Ollama 大模型管理命令大模型的实际运行资源消耗基于 Ollam…...

前端JS接口加密攻防实操

前端JS接口加密攻防实操 背景 在爬虫过程中&#xff0c;对数据接口各类加密的经历总结&#xff0c;无头消耗资源效率不高&#xff0c;采用浏览器兜底解密协程并行 青铜版(混淆对称加密|签名nonce等&#xff09; 解&#xff1a;根据API 调用栈&#xff0c;断点找到request参…...

Python基础--计算机基础

1. 计算机基础 1.1 硬件组成 核心硬件&#xff1a; CPU&#xff1a;负责逻辑运算与指令执行&#xff08;如Intel Core、AMD Ryzen&#xff09;内存&#xff08;RAM&#xff09;&#xff1a;临时存储运行中的程序与数据&#xff08;如DDR4 16GB&#xff09;硬盘&#xff08;HDD…...

计算机考研之数据结构:深入解析最大公约数与欧几里得算法

一、生活中的公约数应用 在日常生活中&#xff0c;经常需要处理"均分分配"问题。例如&#xff1a;要将24块巧克力和18块饼干平均分给小朋友&#xff0c;最多能分给几个小朋友&#xff1f;这就是典型的求最大公约数问题。 二、基本概念详解 约数与公约数 约数&…...

百度搜索融合 DeepSeek 满血版,开启智能搜索新篇

百度搜索融合 DeepSeek 满血版&#xff0c;开启智能搜索新篇 &#x1f680; &#x1f539; 一、百度搜索全量接入 DeepSeek &#x1f539; 百度搜索迎来重要升级&#xff0c;DeepSeek 满血版全面上线&#xff01;&#x1f389; 用户在百度 APP 搜索后&#xff0c;点击「AI」即…...

游戏引擎学习第103天

仓库:https://gitee.com/mrxiao_com/2d_game_2 回顾bug 接下来回顾一下这个bug的具体情况。当前是一个调试视图&#xff0c;我们并不是直接在调试视图下工作&#xff0c;而是在进行相关的调试。展示了地图&#xff0c;这里是环境贴图&#xff0c;上面是正在使用的环境贴图&am…...

WPF快速创建DeepSeek本地自己的客户端-基础思路版本

开发工具&#xff1a;VS 2015 开发环境&#xff1a;.Net 4.0 使用技术&#xff1a;WPF 本篇文章内容&#xff1a; 本地部署DeepSeek以后一般使用网页工具&#xff08;如Chatbox&#xff09;或者DOS窗口与其对话。本篇文章使用WPF创建一个基础版的对话工具。 一、搭建本地DeepS…...

Springboot使用Redis发布订阅自动更新缓存数据源

背景 当项目有很多数据源的时候&#xff0c;通常会在启动的时候就把数据源连接加载缓存上&#xff0c;当数据源进行变更后如何自动实时将缓存的数据源进行更新呢&#xff1f;如果是单个项目直接调接口方法就行了&#xff0c;但是涉及到分布式多个系统呢&#xff1f; 解决方案…...

spring cloud gateway限流常见算法

目录 一、网关限流 1、限流的作用 1. 保护后端服务 2. 保证服务质量 (QoS) 3. 避免滥用和恶意攻击 4. 减少资源浪费 5. 提高系统可扩展性和稳定性 6. 控制不同用户的访问频率 7. 提升用户体验 8. 避免API滥用和负载过高 9. 监控与分析 10. 避免系统崩溃 2、网关限…...

网络安全的态势如何以及如何解决?

大家好,我是AI拉呱,一个专注于人工智领域与网络安全方面的博主,现任资深算法研究员一职,兼职硕士研究生导师;热爱机器学习和深度学习算法应用,深耕大语言模型微调、量化、私域部署。曾获多次获得AI竞赛大奖,拥有多项发明专利和学术论文。对于AI算法有自己独特见解和经验…...

vue3和vue2的组件开发有什么区别

Vue3和Vue2在组件开发上存在不少差异&#xff0c;下面从多个方面详细介绍&#xff1a; 响应式原理 Vue2&#xff1a;用Object.defineProperty()方法来实现响应式。打个比方&#xff0c;它就像给对象的每个属性都安排了一个“小管家”&#xff0c;属性被访问或修改时&#xff0…...

Pytorch实现之粒子群优化算法在GAN中的应用

简介 简介:主要是采用了粒子群优化(PSO)算法来优化GAN的一个训练。PSO是一种是一种基于种群的随机优化技术。这种优化技术是通过粒子群进行的,粒子群在每次迭代中都会更新自己。对于给定的目标函数,这种方法利用一个搜索空间,在那里粒子群移动,找到所需的全局最小值。这…...

2026考研趋势深度解析:政策变化+高效工具指南

2026考研深度解析&#xff1a;趋势洞察高效工具指南&#xff0c;助你科学备战上岸 从政策变化到工具实战&#xff0c;这份千字攻略解决99%考生的核心焦虑 【热点引入&#xff1a;考研赛道进入“高难度模式”】 2025年全国硕士研究生报名人数突破520万&#xff0c;报录比预计扩…...

AI工具篇:利用DeepSeek+Kimi 辅助生成综述汇报PPT

随着科研和学术报告需求的增加&#xff0c;如何高效地准备一份结构清晰、内容充实的PPT已成为许多研究者的挑战。 传统的PPT制作过程繁琐&#xff0c;需要大量文献收集、数据分析和设计工作&#xff0c;而AI工具能够帮助提升效率&#xff0c;减少重复劳动。 本文将介绍如何使用…...

【Linux系统】—— 调试器 gdb/cgdb的使用

【Linux系统】—— 调试器 gdb/cgdb的使用 1 前置准备2 快速认识 gdb3 cgdb/gdb 的使用3.1 简单认识 cgdb3.2 打断点 / 删断点3.3 逐过程 / 逐语句3.4 查看变量3.5 快速跳转 4 cgdb/gdb 调试技巧4.1 watch4.2 「set var」确定问题原因4.3 条件断点 5 概念理解6 gdb/cgdb 指令一…...

Vue 3 中,Pinia 和 Vuex 的主要区别

总结对比表 对比项VuexPiniaAPI 设计区分 mutations/actions仅 state/actions/getters模块化嵌套式配置独立 Store&#xff0c;按需组合TypeScript需手动声明类型原生自动推断代码简洁性冗余&#xff08;需 commit/dispatch&#xff09;直接调用方法推荐场景Vue 2 升级项目/严…...

Wireshark 输出 数据包列表本身的值

在 Wireshark 中&#xff0c;如果你想输出数据包列表本身的值&#xff08;例如&#xff0c;将数据包的摘要信息、时间戳、源地址、目的地址等导出为文本格式&#xff09;&#xff0c;可以使用 导出为纯文本文件 的功能。以下是详细步骤&#xff1a; 步骤 1&#xff1a;打开 Wir…...

docker部署单机版doris,完整无坑

文章目录 一、部署1、修改内核参数2、下载Docker 开发环境镜像3、下载安装包4、启动镜像5、配置fe6、配置be7、远程连接 二、运维命令参考资料 一、部署 1、修改内核参数 在启动doris的be时&#xff0c;需要将 Linux 操作系统的内核参数设置为2000000&#xff0c;这里是Doris…...

SQL注入(SQL Injection)详解与实战

文章目录 一、什么是SQL注入&#xff1f;二、常见SQL注入类型三、手动注入步骤&#xff08;以CTF题目为例&#xff09;四、CTF实战技巧五、自动化工具&#xff1a;SQLMap六、防御措施七、CTF例题八、资源推荐 一、什么是SQL注入&#xff1f; SQL注入是一种通过用户输入构造恶意…...

STM32 低功耗模式

目录 背景 低功耗模式 睡眠模式 进入睡眠模式 退出睡眠模式 停止模式 进入停止模式 退出停止模式 待机模式 进入待机模式 退出待机模式 程序 睡眠模式 休眠模式配置 进入休眠模式 退出睡眠模式 停止模式 停止模式配置 进入停止模式 退出停止模式 待机模式…...

网络安全架构战略 网络安全体系结构

本节书摘来自异步社区《网络安全体系结构》一书中的第1章&#xff0c;第1.4节&#xff0c;作者【美】Sean Convery 1.4 一切皆为目标 网络安全体系结构 当前的大型网络存在着惊人的相互依赖性&#xff0c;作为一名网络安全设计师&#xff0c;对这一点必须心知肚明。Internet就…...

【算法】回溯算法

回溯算法 什么是回溯 人生无时不在选择。在选择的路口&#xff0c;你该如何抉择 ..... 回溯&#xff1a; 是一种选优搜索法&#xff0c;又称为试探法&#xff0c;按选优条件向前搜索&#xff0c;以达到目标。但当探索到某一步时&#xff0c;发现原先选择并不优或达不到目标&am…...