VueUse的使用

VueUse的使用

VueUse 是基于 Vue 3 Composition API 封装的"工具函数"集合,被社区称为"Vue 瑞士军刀"。它把项目中反复出现的逻辑(本地存储、鼠标位置、防抖节流、剪贴板、全屏、息屏检测......)全部做成"可组合函数(Composable)",直接在 setup() 里 import 就能用,无需再自己写一堆样板代码。

一、安装与按需引入

  1. 安装核心包
bash 复制代码
npm i @vueuse/core
# 如需要音效、动画、路由等再装对应扩展包
npm i @vueuse/sound @vueuse/motion @vueuse/router
  1. 按需引入
js 复制代码
// 只拿需要的函数
import { useMouse, useLocalStorage, useDebounceFn } from '@vueuse/core'

二、10 行代码就能跑起来的 6 个高频场景

需求 关键 API 最小可运行片段
1. 实时鼠标坐标 useMouse const { x, y } = useMouse() 直接绑定模板 {``{ x }},{``{ y }}
2. 本地存储双向绑定 useStorage const name = useStorage('uname', 'tom') 输入框 v-model="name" 刷新仍保存
3. 按钮防抖 useDebounceFn const submit = useDebounceFn(() => api(), 500) 快速点击只执行 1 次
4. 元素是否进可视区 useElementVisibility const target = ref(); const isShow = useElementVisibility(target) 做"懒加载/埋点"利器
5. 一键复制 useClipboard const { copy, isSupported } = useClipboard() copy('文本') 自动兼容旧浏览器
6. 页面标题动态化 useTitle useTitle computed(()=> 未读${count} 条消息) 微信未读红点同款

三、进阶:组合多个函数做业务

需求:做一个"拖拽上传"区域,要求

  • 进入页面临时改标题
  • 拖拽时高亮区域
  • 松手后调接口并防抖
  • 上传结果写入本地缓存,刷新可恢复列表
vue 复制代码
<script setup>
import { ref, computed } from 'vue'
import {
  useTitle, useDropZone, useDebounceFn, useLocalStorage
} from '@vueuse/core'

// 1. 标题
useTitle(computed(() =>
  files.value.length ? `已选 ${files.value.length} 个文件` : '拖拽上传 Demo'
))

// 2. 列表 + 缓存
const files = useLocalStorage('upload-files', [])

// 3. 拖拽区域
const dropRef = ref()
const { isOverDropZone } = useDropZone(dropRef, (droppedFiles) => {
  upload(droppedFiles.map(f => f.name))
})

// 4. 防抖上传
const upload = useDebounceFn((newFiles) => {
  // 模拟接口
  files.value = [...files.value, ...newFiles]
}, 600)
</script>

<template>
  <div
    ref="dropRef"
    class="box"
    :class="{ active: isOverDropZone }"
  >
    把文件拖进来(已缓存 {{ files.length }} 个)
  </div>
</template>

<style scoped>
.box { border: 2px dashed #ccc; padding: 40px; }
.active { border-color: #42b883; background: #f0f9ff; }
</style>

上面 30 行代码即完成"标题变化 + 拖拽高亮 + 防抖上传 + 本地缓存"完整链路,无需手动 addEventListener、setTimeout、localStorage.setItem

相关推荐
悟空瞎说几秒前
前端老鸟实战:纯 CSS 实现小红书「真・瀑布流」,零 JS、自动错落、生产可用
前端
yuki_uix几秒前
当 reduce 遇到二维数据:从"聚合直觉"到"复合 Map"的思维跃迁
前端·javascript·面试
我叫黑大帅4 分钟前
Vue3中的computed 与 watch 的区别
前端·javascript·面试
暗不需求6 分钟前
# 一文搞懂 JavaScript 内存机制:从栈和堆,到闭包为什么“活得更久”
前端·javascript
CharlesY6 分钟前
JavaScript HTML5 Cache Manifest:离线应用缓存机制考古
前端·javascript
yuki_uix6 分钟前
前端解题的 6 个思维模型:比记答案更有用的东西
前端·面试
Bigger22 分钟前
第三章:我是如何剖析 Claude Code 工具系统与命令执行机制的
前端·claude·源码阅读
GISer_Jing30 分钟前
告别手搓架构图!Excalidraw+AI Skills 高效绘制手绘风技术图
前端·人工智能·react.js
jiayong2332 分钟前
第 7 课:第三轮真实重构,拆出新增任务弹窗
服务器·前端·重构
钛态32 分钟前
前端WebSocket实时通信:别再用轮询了!
前端·vue·react·web