【亲测免费】 探索 Vue-Sortable:一款强大的 Vue.js 可排序组件
2026-01-14 18:19:00作者:滑思眉Philip
是一个轻量级但功能齐全的 Vue.js 插件,它允许用户在界面上自由地拖放元素以实现列表排序。对于需要构建交互式、动态数据展示的前端开发者来说,这是一个不可或缺的工具。
项目简介
Vue-Sortable 是基于 Sortable.js 的 Vue 版本,提供了与 Vue 生态系统紧密集成的接口和生命周期钩子。它支持原生 HTML5 拖放 API,并且具有很好的浏览器兼容性。通过简单易用的 API,你可以快速将排序功能添加到 Vue 应用的任何列表中。
技术分析
安装
Vue-Sortable 可以通过 npm 或 yarn 快速安装:
npm install --save vue-sortable
# 或者
yarn add vue-sortable
使用
在你的 Vue 组件中,导入并注册 vue-sortable,然后在模板中使用 <sortable> 标签:
import { Sortable } from 'vue-sortable'
export default {
components: {
Sortable,
},
data() {
return {
items: ['Item 1', 'Item 2', 'Item 3'],
}
},
}
<template>
<div>
<sortable v-model="items" @update="onUpdate">
<li v-for="(item, index) in items" :key="index">{{ item }}</li>
</sortable>
</div>
</template>
<script>
...
methods: {
onUpdate(newOrder) {
console.log('更新后的顺序:', newOrder)
},
}
...
</script>
功能特性
- 双向绑定 - 使用
v-model直接绑定你的数据列表。 - 事件驱动 - 提供了丰富的事件(如
update,start,end等)以便在排序过程中进行处理。 - 自定义指令 - 如果你喜欢使用 Vue 自定义指令,Vue-Sortable 同样提供了一个
v-sorte指令。 - 插槽支持 - 支持 Vue 的插槽机制,方便自定义列表项的结构和样式。
- 兼容性好 - 兼容 Vue 2 和 Vue 3,同时也适用于 Server-side Rendering (SSR)。
应用场景
Vue-Sortable 可用于各种需要动态调整元素顺序的场合,例如:
- 列表排序,如任务管理器中的任务列表。
- 图片网格排序,如相册应用。
- 数据库记录排序,如数据库可视化工具。
结语
Vue-Sortable 将排序功能的实现变得简单而直观。无论是新手还是经验丰富的 Vue 开发者,都能快速上手并享受到其带来的便利。不妨在你的下一个 Vue 项目中尝试一下,看看如何提升用户体验吧!
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0214
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0138
uni-appA cross-platform framework using Vue.jsJavaScript08
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03
项目优选
收起
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
469
465
暂无描述
Dockerfile
778
5.08 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
877
2.03 K
Ascend Extension for PyTorch
Python
758
968
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
697
1.4 K
昇腾LLM分布式训练框架
Python
185
231
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.1 K
1.14 K
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.25 K
677