热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Vue新玩具VueUse

点击上方前端Q,关注公众号回复加群,加入前端Q技术交流群前言上次在看前端早早聊大会中,尤大大再一次提到了VueUse的一个库。好奇了一下&

点击上方 前端Q,关注公众号

回复加群,加入前端Q技术交流群

前言

上次在看前端早早聊大会中, 尤大大再一次提到了 VueUse 的一个库。好奇了一下,点看看了看。好家伙啊, 我直接好家伙。这不就是曾经我也想自己写一个 vue 版的 hooks 库吗?(因为我觉得 vue3hooks 太像了) 可是我还不太会, 你现在直接把我的梦想给破灭了,下面我们一起来看看吧!VueUse 作者 Anthony Fu 分享可组合的 Vue_哔哩哔哩_bilibili

长按识别二维码查看原文

https://www.bilibili.com/video/BV1x54y1V7H6

55df4d983e782202d6a8955225609d3b.png      

什么是 VueUse

VueUse 是一个基于 Composition API 的实用函数集合。通俗的来说,这就是一个工具函数包,它可以帮助你快速实现一些常见的功能,免得你自己去写,解决重复的工作内容。以及进行了基于 Composition API 的封装。让你在 vue3 中更加得心应手。

简单上手

安装 VueUse

npm i @vueuse/core

使用 VueUse

// 导入
import { useMouse, usePreferredDark, useLocalStorage } from '@vueuse/core'export default {setup() {// tracks mouse positionconst { x, y } = useMouse()// is user prefers dark themeconst isDark = usePreferredDark()// persist state in localStorageconst store = useLocalStorage('my-storage',{name: 'Apple',color: 'red',},)return { x, y, isDark, store }}
}

上面从 VueUse 当中导入了三个函数, useMouse, usePreferredDark, useLocalStorageuseMouse 是一个监听当前鼠标坐标的一个方法,他会实时的获取鼠标的当前的位置。usePreferredDark 是一个判断用户是否喜欢深色的方法,他会实时的判断用户是否喜欢深色的主题。useLocalStorage 是一个用来持久化数据的方法,他会把数据持久化到本地存储中。

还有我们熟悉的 「防抖」 和 「节流」

import { throttleFilter, debounceFilter, useLocalStorage, useMouse } from '@vueuse/core'// 以节流的方式去改变 localStorage 的值
const storage = useLocalStorage('my-key', { foo: 'bar' }, { eventFilter: throttleFilter(1000) })// 100ms后更新鼠标的位置
const { x, y } = useMouse({ eventFilter: debounceFilter(100) })

还有还有在 component 中使用的函数

上面例子中,使用了 onClickOutside 函数,这个函数会在点击元素外部时触发一个回调函数。也就是这里的 close 函数。在 component 中就是这么使用

注意⚠️ 这里的 OnClickOutside 函数是一个组件,不是一个函数。需要package.json 中安装了 @vueuse/components

还还有全局状态共享的函数

// store.js
import { createGlobalState, useStorage } from '@vueuse/core'export const useGlobalState = createGlobalState(() => useStorage('vue-use-local-storage'),
)

// component.js
import { useGlobalState } from './store'export default defineComponent({setup() {const state = useGlobalState()return { state }},
})

这样子就是一个简单的状态共享了。扩展一下。传一个参数,就能改变 store 的值了。

还有关于 fetch, 下面👇就是一个简单的请求了。

import { useFetch } from '@vueuse/core'const { isFetching, error, data } = useFetch(url)

它还有很多的 option 参数,可以自定义。

// 100ms超时
const { data } = useFetch(url, { timeout: 100 })

// 请求拦截
const { data } = useFetch(url, {async beforeFetch({ url, options, cancel }) {const myToken = await getMyToken()if (!myToken)cancel()options.headers = {...options.headers,Authorization: `Bearer ${myToken}`,}return {options}}
})

// 响应拦截
const { data } = useFetch(url, {afterFetch(ctx) {if (ctx.data.title === 'HxH')ctx.data.title = 'Hunter x Hunter' // Modifies the resposne datareturn ctx},
})

更多

更多还的看VueUse 文档,还有另一个项目,说不定你就需要 vue-demi

长按识别二维码查看原文

https://vueuse.org/

0cc3b78f02960452737aeb8dbbe03629.png      

长按识别二维码查看原文

https://github.com/vueuse/vue-demi

767bb39642b371faf2683cd326c42cb9.png      

作者:我只是一个小菜鸡

原文链接:https://juejin.cn/post/7029699344596992031

4d9869d34a6802f66cb39963930a4570.png

往期推荐

大厂面试过程复盘(微信/阿里/头条,附答案篇)

09963d39ebc2e111c5c029f25b0d8c65.png

面试题:说说事件循环机制(满分答案来了)

17b4e4632f5ec7a9e1bcfccb1bf1fdcb.png

专心工作只想搞钱的前端女程序员的2020

a2d136aa4a2a683a3cea60cfec99ff27.png


最后

  • 欢迎加我微信,拉你进技术群,长期交流学习...

  • 欢迎关注「前端Q」,认真学前端,做个专业的技术人...

904aeed4858f37f4d3dbf6a1df70ebbc.png

f80ee5de93fa452a5e5f9a668e3ab32f.png

点个在看支持我吧

0027615d177b23fc53cc63ad6d7fb197.gif


推荐阅读
author-avatar
奇国的雪儿
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有