news 2026/4/15 15:29:51

在 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/4/15 15:26:35

5分钟快速上手:轻量级Node.js线程池Tinypool终极指南

5分钟快速上手:轻量级Node.js线程池Tinypool终极指南 【免费下载链接】tinypool 🧵 A minimal and tiny Node.js Worker Thread Pool implementation (38KB) 项目地址: https://gitcode.com/gh_mirrors/ti/tinypool 在当今高并发的Web应用开发中&…

作者头像 李华
网站建设 2026/4/15 15:27:44

AudioGridder终极指南:实现音频插件远程处理的完整解决方案

AudioGridder终极指南:实现音频插件远程处理的完整解决方案 【免费下载链接】audiogridder DSP servers using general purpose computers and networks 项目地址: https://gitcode.com/gh_mirrors/au/audiogridder 在音频制作领域,CPU密集型插件…

作者头像 李华
网站建设 2026/4/15 15:29:48

Ingress-NGINX镜像瘦身实战:从臃肿到精炼的架构重塑

Ingress-NGINX镜像瘦身实战:从臃肿到精炼的架构重塑 【免费下载链接】ingress-nginx Ingress-NGINX Controller for Kubernetes 项目地址: https://gitcode.com/GitHub_Trending/in/ingress-nginx 面对日益增长的微服务部署需求,传统ingress-ngin…

作者头像 李华
网站建设 2026/4/13 10:00:41

零基础掌握hal_uartex_receivetoidle_dma在工业控制板上的调试技巧

如何用好STM32的空闲中断DMA?工业通信调试实战全解析你有没有遇到过这样的场景:MCU正在跑复杂的控制算法,突然来了一串Modbus报文,结果因为CPU太忙没及时读取UART数据,导致帧丢失、CRC校验失败?或者为了接收…

作者头像 李华
网站建设 2026/4/15 9:02:20

为什么顶尖团队都在用C重写Python函数?:揭秘性能瓶颈破局之道

第一章:为什么顶尖团队都在用C重写Python函数?在高性能计算和系统级优化领域,越来越多的顶尖技术团队选择将关键的Python函数用C语言重写。这一趋势的背后,是对执行效率、资源占用和可扩展性的极致追求。性能差距显著 Python作为动…

作者头像 李华