news 2026/2/2 3:42:55

在 Vue 3 的 setup() 函数中,this 是 undefined。

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
在 Vue 3 的 setup() 函数中,this 是 undefined。

Vue3的setup()函数中this为undefined,这是Composition API的重要改变。


替代方案包括:通过参数直接访问props和context(包含attrs、slots、emit等),使用解构语法简化写法。


相比Options API,Composition API不再依赖this,而是通过显式参数访问组件属性和方法,如用emit()替代this.$emit,用ref替代this.$el。


这种设计使代码更清晰明确,提升了TypeScript支持度,减少了this的"魔术性"访问。


在 Vue 3 的setup()函数中,thisundefined

这是 Vue 3 Composition API 的一个重要改变。


为什么this是 undefined?

setup()函数中,组件实例尚未被完全创建,所以this不可用。


替代方案

1.访问 Props

import { defineProps } from 'vue'; export default { props: ['title'], setup(props) { // props 作为第一个参数 console.log(props.title); // ✅ 正确 // console.log(this.title); // ❌ 错误!this 是 undefined } };

2.访问 Context(上下文)

export default { setup(props, context) { // context 作为第二个参数 // context 包含以下属性: console.log(context.attrs); // 非 props 的属性 console.log(context.slots); // 插槽 console.log(context.emit); // 触发事件的方法 console.log(context.expose); // 暴露公共属性 } };

3.使用解构语法

export default { setup(props, { attrs, slots, emit, expose }) { emit('myEvent', 'data'); // ✅ 触发事件 } };

4.完整示例

import { ref } from 'vue'; export default { props: ['initialCount'], emits: ['count-changed'], // 声明自定义事件 setup(props, { emit }) { const count = ref(props.initialCount || 0); const increment = () => { count.value++; emit('count-changed', count.value); // 使用 emit 而不是 this.$emit }; return { count, increment }; } };

与 Options API 的对比

// Options API (Vue 2 / Vue 3 兼容) export default { mounted() { console.log(this.$el); // ✅ 可以访问 console.log(this.$props); // ✅ 可以访问 this.$emit('event'); // ✅ 可以访问 } }; // Composition API export default { setup(props, { emit }) { onMounted(() => { // console.log(this.$el); // ❌ 错误!this 是 undefined console.log(props); // ✅ 使用 props 参数 emit('event'); // ✅ 使用 context.emit }); // 如果需要访问模板引用,使用 ref const myElement = ref(null); return { myElement // 在模板中通过 ref="myElement" 绑定 }; } };

主要变化总结

Options APIComposition API
this.$emit()emit()(从 context 获取)
this.$propsprops(setup 参数)
this.$attrsattrs(从 context 获取)
this.$slotsslots(从 context 获取)
this.$el模板引用 (ref)
this.$parent避免使用,考虑 Provide/Inject

这种设计让代码更加明确,减少了this的魔术性,提高了 TypeScript 的支持度。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/30 19:01:41

FreeRTOS: 队列(Queues)与任务间通信 — API 深入与实战

队列(Queues)与任务间通信 — API 深入与实战 在嵌入式实时系统里,队列并不是一个抽象的学术概念,它就是你在任务之间传递消息、转移轻量事件、把 ISR 做不了的事情交给任务处理的那根“绳子”。我下面把队列的要点、常用 API、设…

作者头像 李华
网站建设 2026/1/23 18:13:59

FaceFusion批处理模式终极指南:5步搞定大规模人脸处理任务

FaceFusion批处理模式终极指南:5步搞定大规模人脸处理任务 【免费下载链接】facefusion Next generation face swapper and enhancer 项目地址: https://gitcode.com/GitHub_Trending/fa/facefusion 还在为处理海量人脸图片而烦恼吗?FaceFusion批…

作者头像 李华
网站建设 2026/1/30 21:10:24

Python性能卡顿怎么办?:立即掌握C语言重写热点函数的4种方法

第一章:Python性能瓶颈的根源分析Python作为一门高级动态语言,以其简洁语法和丰富的生态广受欢迎。然而在高性能计算、大规模数据处理等场景中,其运行效率常成为系统瓶颈。深入理解性能问题的根源,是优化的前提。全局解释器锁&…

作者头像 李华
网站建设 2026/1/31 13:58:07

五行—八卦系统理论框架[基于新三论,以及数字建模需要整理]

五行—八卦系统理论框架(Wuxing–Bagua Systems Framework, WBSF) 0. 目标与适用范围 目标:用统一语言刻画复杂系统的 结构(系统如何组成、如何联结) 功能(系统如何运行、如何分工) 信息(系统如何感知、如何编码与决策) 控制(系统如何稳定、如何纠偏与进化) 适用:…

作者头像 李华