Vue 新玩具 VueUse

news/2024/7/10 1:28:13 标签: python, vue, java, react, js
js_content">

作者:我只是一个小菜鸡

https://juejin.cn/post/7029699344596992031

什么是 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 position
    const { x, y } = useMouse()

    // is user prefers dark theme
    const isDark = usePreferredDark()

    // persist state in localStorage
    const 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 中使用的函数

<script setup>
import { ref } from  vue 
import { onClickOutside } from  @vueuse/core 

const el = ref()

function close () {
  /* ... */
}

onClickOutside(el, close)
</script>

<template>
  <section ref="el">
    Click Outside of Me
  </section>
</template>

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

<script setup>
import { OnClickOutside } from  @vueuse/components 

function close () {
  /* ... */
}
</script>

<template>
  <OnClickOutside @trigger="close">
    <section>
      Click Outside of Me
    </section>
  </OnClickOutside>
</template>

注意⚠️ 这里的 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 data

    return ctx
  },
})

eef96268f67c1b96a6d4780b93a3a5f5.png

点个在看支持我吧,转发就更好了


http://www.niftyadmin.cn/n/1251097.html

相关文章

Linux下怎么检查端口号是否能访问

检查ip是否能访问我们用 ping ip 那么检查端口号是否能访问我们用 telnet ip port 如果执行不了&#xff0c;先yum安装下就好了 yum install telnet

来,上一上 IT 历史课!

雏形初现 给你一台 1804 的织布机&#xff0c;你能想象它是计算机的灵感来源吗&#xff1f;没错&#xff0c;那一年法国发明家雅卡尔发明了高效率的织布机&#xff0c;他通过对穿孔的有无来控制了编织的图案。 这种打孔模式其实就是变相的在存储图案路线&#xff0c;再用机械…

Linux查看端口占用情况,并强制释放占用的端口

1.查找被占用的端口 netstat -tln netstat -tln | grep 8080 netstat -tln 查看端口使用情况&#xff0c;而netstat -tln | grep 8080则是只查看端口8080的使用情况 2.查看端口属于哪个程序&#xff1f;端口被哪个进程占用 lsof -i:8060 COMMAND PID USER FD TYPE …

mysql 系列:搞定索引

摘要 索引是数据库里重要的组成部分&#xff0c;也是提高查询效率必备的知识点。本文将会介绍索引作用、索引类型、索引优化以及索引底层结构&#xff0c;也算是对索引知识的一次归纳。 一、索引介绍 什么是索引&#xff1f; 数据库是用来存储与读取数据的&#xff0c;如何…

压力测试工具、Web性能压力测试工具ApacheBench(ab)详解

网站性能压力测试是性能调优过程中必不可少的一环。只有让服务器处在高压情况下才能真正体现出各种设置所暴露的问题。Apache中有个自带的&#xff0c;名为ab的程序&#xff0c;可以对Apache或其它类型的服务器进行网站访问压力测试。 ApacheBench命令原理&#xff1a; ab命令…

mysql 系列:锁和它的运用

前言 数据库是一个允许多用户、多会话、多线程访问的系统。为了在并发访问中能保证数据的一致性和完整性&#xff0c;一般会使用事务来做控制&#xff0c;外加锁来作为辅助手段。所以今天整理了一下锁的相关知识&#xff0c;看看它在事务里是怎么配合使用的。 锁的分类 我们…

nginx配置跨域请求Access-Control-Allow-Origin

当出现403跨域错误的时候 No Access-Control-Allow-Origin header is present on the requested resource&#xff0c;需要给Nginx服务器配置响应的header参数&#xff1a; 一、 解决方案 只需要在Nginx的配置文件中配置以下参数&#xff1a; location / { add_header Acce…

mysql 系列:日志

摘要 日志的存在&#xff0c;为数据库的很多功能提供了保障。像用于回滚数据的 undo log&#xff0c;用于恢复数据的 redo log&#xff0c; 以及用于主从备份的 binlog。本文将会大致介绍下数据库里的日志类别&#xff0c;以及重点分析下事务日志的相关知识点。 日志分类 在…