Vue3 Composition API 深度开发指南

Vue3 Composition API 深度开发指南

在这里插入图片描述

响应式系统核心解析

1.1 响应式原理解构

Vue3 基于 Proxy 实现响应式追踪,其核心流程为:

const reactiveHandler = {get(target, key, receiver) {track(target, key) // 依赖收集return Reflect.get(target, key, receiver)},set(target, key, value, receiver) {const result = Reflect.set(target, key, value, receiver)trigger(target, key) // 触发更新return result}
}function reactive(obj) {return new Proxy(obj, reactiveHandler)
}

关键差异

  • ref 通过对象包装实现基础类型响应式
  • reactive 直接代理整个对象
  • shallowRef/shallowReactive 实现浅层响应

1.2 响应式工具进阶

// 响应式转换控制
const readonlyUser = readonly(reactive({ name: 'Alice' }))// 解构保持响应性
const { x, y } = toRefs(reactiveMousePosition)// Ref类型自动解包
const count = ref(0)
const double = computed(() => count.value * 2)

组件设计模式深度实践

2.1 受控组件模式

// 通用表单控制逻辑
export function useFormControl<T>(initialValue: T) {const value = ref<T>(initialValue)const touched = ref(false)const setValue = (newValue: T) => {value.value = newValuetouched.value = true}return {value: readonly(value),isTouched: readonly(touched),setValue}
}// 组件实现
const emailControl = useFormControl<string>('')

2.2 依赖注入模式

// 上下文类型定义
interface EditorContext {content: Ref<string>formatters: Map<string, FormatterFn>
}// 提供者组件
const editorSymbol = Symbol() as InjectionKey<EditorContext>provide(editorSymbol, {content: ref(''),formatters: new Map([['bold', text => `**${text}**`]])
})// 消费者组件
const { formatters } = inject(editorSymbol)!

Composition API 高级模式

3.1 异步状态机

type AsyncState<T> = {data: T | nullerror: Error | nullstatus: 'idle' | 'pending' | 'success' | 'error'
}export function useAsyncTask<T>(task: () => Promise<T>) {const state = reactive<AsyncState<T>>({data: null,error: null,status: 'idle'})const execute = async () => {state.status = 'pending'try {state.data = await task()state.status = 'success'} catch (err) {state.error = err as Errorstate.status = 'error'}}return { state, execute }
}// 使用示例
const { state, execute } = useAsyncTask(fetchUserList)

3.2 响应式存储模式

class ReactiveStore<T extends object> {private state: Tprivate proxy: Tconstructor(initialState: T) {this.state = initialStatethis.proxy = reactive(initialState) as T}getState(): Readonly<T> {return readonly(this.proxy)}mutate(mutation: (state: T) => void) {mutation(this.proxy)}
}// 创建Store实例
const userStore = new ReactiveStore({id: 0,profile: { name: '' }
})// 组件中使用
const { id } = userStore.getState()

性能优化策略

4.1 计算属性缓存策略

const heavyList = ref<Item[]>(/* 大数据集 */)// 带缓存的筛选计算
const filteredList = computed(() => {return heavyList.value.filter(item => item.category === 'active' && item.value > 1000)
})// 计算属性调试
const debugComputed = computed({get() { /* 原逻辑 */ },set() { /* 开发环境调试钩子 */ }
})

4.2 虚拟滚动优化

// 虚拟滚动Composable
export function useVirtualScroll(options: {containerRef: Ref<HTMLElement | null>itemHeight: numbertotalItems: number
}) {const scrollTop = ref(0)const visibleCount = computed(() => Math.ceil(options.containerRef.value!.clientHeight / options.itemHeight))const startIndex = computed(() =>Math.floor(scrollTop.value / options.itemHeight))const endIndex = computed(() =>Math.min(startIndex.value + visibleCount.value + 2, options.totalItems))return { scrollTop, startIndex, endIndex }
}

类型系统深度集成

5.1 复杂类型推导

// 类型安全的provide/inject
const LOCALE_KEY = Symbol() as InjectionKey<{lang: Ref<string>setLang: (lang: string) => void
}>// Props类型增强
interface ModalProps {modelValue: booleantitle?: stringtransition?: 'fade' | 'slide'
}const props = defineProps<ModalProps>()// Emits类型约束
const emit = defineEmits<{(e: 'update:modelValue', value: boolean): void(e: 'confirm', payload: { timestamp: number }): void
}>()

5.2 泛型Composable

interface PaginationOptions<T> {initialPage: numberpageSize: numberfetcher: (page: number) => Promise<T[]>
}export function usePagination<T>(options: PaginationOptions<T>) {const currentPage = ref(options.initialPage)const list = ref<T[]>([]) as Ref<T[]>const loadPage = async () => {list.value = await options.fetcher(currentPage.value)}return {currentPage,list,loadPage}
}// 使用示例
const { list, loadPage } = usePagination<User>({initialPage: 1,pageSize: 20,fetcher: fetchUsers
})

工程化实践

6.1 自定义指令开发

// 权限控制指令
const vPermission = {mounted(el: HTMLElement, binding: DirectiveBinding<string[]>) {const userPermissions = useAuthStore().permissionsif (!binding.value.some(perm => userPermissions.includes(perm))) {el.parentNode?.removeChild(el)}}
}// 使用方式
<button v-permission="['admin', 'editor']">删除</button>

6.2 单元测试策略

// 测试Composable
import { useCounter } from './counter'
import { renderHook } from '@testing-library/vue'test('counter logic', async () => {const { result } = renderHook(() => useCounter(10))expect(result.current.count.value).toBe(10)await result.current.increment()expect(result.current.count.value).toBe(11)await result.current.reset()expect(result.current.count.value).toBe(10)
})

响应式调试技巧

7.1 依赖追踪可视化

// 调试watch效果
const stop = watchEffect((onCleanup) => {console.log('依赖变化:', effectScope.activeEffect?.deps)onCleanup(() => {console.log('清理副作用')})
})// Chrome DevTools + Vue DevTools 组合调试

7.2 响应式树分析

import { DebuggerEvent, debug } from 'vue'debug({onTrack(e: DebuggerEvent) {if (e.target === store) {console.log('Store被追踪:', e)}},onTrigger(e: DebuggerEvent) {console.log('响应式触发:', e)}
})

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/75929.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于自回归模型的酒店评论生成

《DeepSeek大模型高性能核心技术与多模态融合开发&#xff08;人工智能技术丛书&#xff09;》(王晓华)【摘要 书评 试读】- 京东图书 我们使用新架构的模型完成情感分类&#xff0c;可以看到&#xff0c;使用注意力机制可以很好地对特征进行抽取从而完成二分类的情感分类任务…

关于转置卷积

&#x1f9e0; 具体讲解神经网络中的转置卷积&#xff08;Transposed Convolution&#xff09; &#x1f9ed; 1. 转置卷积的动机&#xff1a;为什么我们需要它&#xff1f; 标准卷积通常会降低特征图的空间尺寸&#xff08;比如从 64x64 → 32x32&#xff09;&#xff0c;这对…

JavaScript 模块化详解( CommonJS、AMD、CMD、ES6模块化)

一.CommonJS 1.概念 CommonJS 规范概述了同步声明依赖的模块定义。这个规范主要用于在服务器端实现模块化代码组 织&#xff0c;但也可用于定义在浏览器中使用的模块依赖。CommonJS 模块语法不能在浏览器中直接运行&#xff1b;在浏览器端&#xff0c;模块需要提前编译打包处理…

TCP BBR 的优化

前段时间&#xff0c;老板发了篇资料&#xff0c;下面是我学习的相关记录整理。 https://aws.amazon.com/cn/blogs/china/talking-about-network-optimization-from-the-flow-control-algorithm/ PS&#xff1a;ubuntu24默认使用的tcp控制算法。还是 cubic sysctl net.ipv4.tc…

什么是异步?

什么是异步&#xff1f; 异步是一个术语&#xff0c;用于描述不需要同时行动或协调就能独立运行的流程。这一概念在技术和计算领域尤为重要&#xff0c;它允许系统的不同部分按自己的节奏运行&#xff0c;而无需等待同步信号或事件。在区块链技术中&#xff0c;异步是指网络中…

SSM婚纱摄影网的设计

&#x1f345;点赞收藏关注 → 添加文档最下方联系方式咨询本源代码、数据库&#x1f345; 本人在Java毕业设计领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目希望你能有所收获&#xff0c;少走一些弯路。&#x1f345;关注我不迷路&#x1f345; 项目视频 SS…

石头剪刀布游戏

自己写的一个石头剪刀布游戏&#xff0c;如果有需要更改的地方请指出 #define _CRT_SECURE_NO_WARNINGS // scanf_s编写起来太过于麻烦&#xff0c;直接把这个警告关掉&#xff0c;便于编写。 #include <stdio.h> #include <stdlib.h> #include <time.h> //…

大数据系列之:Kerberos

大数据系列之&#xff1a;Kerberos 基本概念工作流程安全特性应用场景总结加密原理Kerberos认证流程更改您的密码授予账户访问权限票证管理Kerberos 票据属性使用 kinit 获取票据使用 klist 查看票据使用 kdestroy 销毁票据.k5identity 文件描述 Kerberos 是一种网络认证协议&a…

WPF 免费UI 控件HandyControl

示例效果和代码 直接可以用 Button 按钮 | HandyOrg 1.安装 , 输入 HandyControl 2.<!--配置HandyControl--> <!--配置HandyControl--> <ResourceDictionary Source"pack://application:,,,/HandyControl;component/Themes/SkinDefault.xaml"/> …

windows部署docker

1.下载docker 打开浏览器&#xff0c;访问 Docker Desktop 下载页面。 2.安装 Docker Desktop 运行安装程序&#xff1a; 双击下载的 Docker Desktop 安装包&#xff0c;启动安装程序。 选择安装选项&#xff1a; 按照屏幕上的指示进行操作。建议选择默认选项&#xff0c;包…

【Linux】远程登录时,使用图形界面报错:MoTTY X11 proxy: Unsupported authorisation protocol

1、问题描述 使用 MobaXterm 远程登录Ubuntu后,使用sudo权限运行图形界面程序报错: MoTTY X11 proxy: Unsupported authorisation protocol (gpartedbin:10518): Gtk-WARNING **: 22:01:34.377: cannot open display: localhost:10.02、查看SSH配置 修改 SSH 服务端配置,…

解决 Hugging Face SentenceTransformer 下载失败的完整指南:ProxyError、SSLError与手动下载方案

问题背景 在使用 Hugging Face 的 SentenceTransformer 加载预训练模型 all-MiniLM-L6-v2 时&#xff0c;遇到了以下错误&#xff1a; 代理连接失败&#xff08;ProxyError / SSLError: KRB5_S_TKT_NYV&#xff09;大文件下载中断&#xff08;unexpected EOF while reading&a…

MySQL——DQL的单表查询

1、查询表中所有的字段&#xff08;列&#xff09; 语法&#xff1a;select * from 表名; * 是通配符&#xff0c;用来表示所有的字段&#xff08;列&#xff09;。 select 表示查询哪些列。 from 表示从哪张表中查询。 2、查询表中指定的字段 语法&#xff1a;select 列…

开源RuoYi AI助手平台的未来趋势

近年来&#xff0c;人工智能技术的迅猛发展已经深刻地改变了我们的生活和工作方式。 无论是海外的GPT、Claude等国际知名AI助手&#xff0c;还是国内的DeepSeek、Kimi、Qwen等本土化解决方案&#xff0c;都为用户提供了前所未有的便利。然而&#xff0c;对于那些希望构建属于自…

[WUSTCTF2020]CV Maker1

进来是个华丽的界面&#xff0c;我们先跟随这个网页创造一个用户 发现了一个上传端口&#xff0c;尝试上传一个php文件并抓包 直接上传进不去&#xff0c;加个GIF89A uploads/d41d8cd98f00b204e9800998ecf8427e.php 传入 并且报告了 上传路径&#xff0c;然后使用蚁剑连接

Spring 中的 IOC

&#x1f331; 一、什么是 IOC&#xff1f; &#x1f4d6; 定义&#xff08;通俗理解&#xff09;&#xff1a; IOC&#xff08;Inversion of Control&#xff0c;控制反转&#xff09; 是一种设计思想&#xff1a;对象不再由你自己创建和管理&#xff0c;而是交给 Spring 容器…

Vue2-实现elementUI的select全选功能

文章目录 使用 Element UI 的全选功能自定义选项来模拟全选 在使用 Element UI 的 el-select组件时&#xff0c;实现“全选”功能&#xff0c;通常有两种方式&#xff1a;一种是使用内置的全选功能&#xff0c;另一种是通过自定义选项来模拟全选。 使用 Element UI 的全选功能…

小菜Go:Ubuntu下Go语言开发环境搭建

前置要求Ubuntu环境搭建 文章推荐 此处推荐一个比较好的文章&#xff0c;基本按部就班就欧克~ 安装虚拟机&#xff08;VMware&#xff09;保姆级教程&#xff08;附安装包&#xff09;_vmware虚拟机-CSDN博客 安装可能遇到的问题 虚拟机安装遇到的问题如&#xff1a;Exception…

安卓中app_process运行报错Aborted,怎么查看具体的报错日志

我在pc端生成了一个jar包&#xff0c;可以正常执行&#xff0c;但是导入到安卓的/data/local/tmp下面执行就会报错 执行命令如下&#xff1a; adb shell cd /data/local/tmp app_process -Djava.class.path/data/local/tmp/demo.jar /data/local/tmp com.example.demo.Hello然…

Python 面向对象 - 依赖倒置原则 (DIP)

1. 核心概念 依赖倒置原则(Dependency Inversion Principle, DIP) 是SOLID原则中的"D"&#xff0c;包含两个关键点&#xff1a; 高层模块不应依赖低层模块&#xff0c;二者都应依赖抽象抽象不应依赖细节&#xff0c;细节应依赖抽象 2. 使用场景 典型应用场景 系…