一些可能被忽视的 Vue3 API 附带案例

Vue3 是 Vue.js 的最新版本,它引入了许多新的 API 和改进。以下是一些可能被忽视的 Vue3 API:

reactive:这是 Vue3 中用于创建响应式对象的函数。与 Vue2 中的 data 不同,reactive 返回的对象是响应式的,这意味着当对象的属性发生变化时,视图会自动更新。

复制代码
import { reactive } from 'vue'
const state = reactive({ count: 0 })

ref:这是 Vue3 中用于创建基本类型的响应式引用的函数。与 reactive 类似,ref 返回的对象也是响应式的。

复制代码
import { ref } from 'vue'
const count = ref(0)

computed:这是 Vue3 中用于创建计算属性的函数。计算属性是基于它们的依赖关系进行缓存的,只有在它们的依赖关系发生变化时才会重新计算。

复制代码
import { computed } from 'vue'
const count = ref(0)
const doubleCount = computed(() => count.value * 2)

watchEffect:这是 Vue3 中用于在组件内部监听响应式对象或数组变化的函数。与 watch 不同,watchEffect 会在组件初始化时立即执行回调函数。

复制代码
import { watchEffect } from 'vue'
watchEffect(() => {
  console.log(count.value) // count.value 的变化会被自动监听并执行回调函数
})

toRefs:这是 Vue3 中用于将响应式对象转换为普通对象和其对应的引用的函数。这在需要将响应式对象传递给非响应式上下文时非常有用。

复制代码
import { toRefs } from 'vue'
const state = reactive({ count: 0 })
const { count, ...otherState } = toRefs(state)

customRef:这是 Vue3 中用于创建自定义引用的函数。自定义引用允许你控制引用的行为,例如实现防抖或节流功能。

复制代码
import { customRef, onMounted } from 'vue'
const count = customRef(0)
onMounted(() => {
  console.log(count.value) // count.value 的变化会被自动监听并执行回调函数
})
相关推荐
lichenyang45313 分钟前
JSAPI、NAPI、Biz、Imp:ASCF Demo 如何真正调用系统能力和 C++ 能力
前端
lichenyang45334 分钟前
IPC、JSVM、UIThread、libuv:ASCF 架构图里最容易混的几个词
前端
用户0595401744637 分钟前
Redis记忆存储故障恢复测试踩坑实录:手动测试让我漏掉了2个一致性Bug
前端·css
用户21366100357240 分钟前
Vue2脚手架工程化与Axios集成
前端·vue.js
用户831348593069842 分钟前
Cesium实现黄昏效果:按钮一键控制打开/关闭黄昏效果,滑块拖动实时控制黄昏浓烈度
vue.js·cesium
张元清44 分钟前
React useDebounce Hook:给状态和回调做防抖(2026)
javascript·react.js
我不是外星人1 小时前
我把 Claude Code 搬到网页!自研高颜值 Web 交互工作台
前端·ai编程·claude
mixuecoding1 小时前
零成本搭建全球科技热点情报站:12 个平台,6 小时,0 元
前端
用户059540174461 小时前
用了3年Mock,才发现Redis记忆存储的测试一直漏掉了60%的边界场景
前端·css
石小石Orz1 小时前
AI具身交互:实现一个会说话的3D虚拟伴侣
前端·人工智能·后端