setup 语法糖核心要点

1. 基本语法

javascript 复制代码
<!-- 传统写法 -->
<script lang="ts">
export default {
  setup() {
    let name = '张三'
    function changeName() { name = '李四' }
    return { name, changeName }
  }
}
</script>

<!-- 语法糖写法 -->
<script setup lang="ts">
let name = '张三'
function changeName() { name = '李四' }
// 无需 return,自动暴露给模板
</script>

2. 关键特性

✅ 自动暴露

  • 顶层变量、函数自动暴露给模板
  • 无需手动 return

✅ 组件自动注册

javascript 复制代码
<script setup>
import Person from './Person.vue'
// 无需在 components 中注册,直接使用
</script>
<template>
  <Person/>  <!-- 直接使用 -->
</template>

✅ 编译器宏?

javascript 复制代码
<script setup>
// Props 定义
const props = defineProps<{ message: string }>()

// Emits 定义  
const emit = defineEmits<{ 'my-event': [data: string] }>()

// 暴露方法给父组件
defineExpose({ publicMethod })
</script>

3. 组件名称问题

问题:<script setup> 无法直接设置组件名

javascript 复制代码
<script setup name="Person">  <!-- ❌ 这样不行 -->

解决方案:使用 Vite 插件

javascript 复制代码
npm i vite-plugin-vue-setup-extend -D
javascript 复制代码
// vite.config.ts
import VueSetupExtend from 'vite-plugin-vue-setup-extend'

export default defineConfig({
  plugins: [vue(), VueSetupExtend()]
})

然后就可以:

javascript 复制代码
<script setup name="Person">  <!-- ✅ 现在可以了 -->

对比总结

| 特性 | 传统 setup() | <script setup> |

|------|-------------|------------------|

| 代码量 | 多(需要 return) | 少(自动暴露) |

| 组件注册 | 需要手动注册 | 自动注册 |

| 类型支持 | 一般 | 优秀 |

| 学习成本 | 中等 | 低 |

一句话总结:<script setup> 是 Vue 3 的"零配置"组合式 API,让组件编写更简洁,但需要插件支持组件命名。

相关推荐
skywalk81631 分钟前
段言项目推进6.15 @ Dumate+Trae
开发语言·学习·编程
我命由我123451 分钟前
Android 开发问题:全局的主题颜色设置,导致 CheckBox 控件在勾选状态下不显示样式
android·java·开发语言·java-ee·intellij-idea·intellij idea·android jetpack
喜欢踢足球的老罗6 分钟前
破解 Chrome 扩展的「两世界难题」:MV3 下的 ISOLATED 与 MAIN World 桥接之道
前端·chrome
Cloud_Shy6187 分钟前
解读《Effective Python 3rd Edition》:从练气到老魔(第七章 Item 51)
开发语言·人工智能·笔记·python·学习方法
一拳一个娘娘腔7 分钟前
【第七期】漏洞攻防-前端篇:XSS 与 CSRF —— 当浏览器成为攻击者的“肉鸡”
前端·xss·csrf
AI+程序员在路上7 分钟前
CSP、PP、PV、HM 在 CiA402 标准下的差异解析
linux·c语言·开发语言·嵌入式硬件
nix.gnehc7 分钟前
Python 并发深度解析
服务器·开发语言·python
我是一颗柠檬8 分钟前
【Java项目技术亮点】Leaf号段模式双Buffer优化
java·开发语言·分布式·后端·架构
Cx330❀12 分钟前
【MySQL基础】详解MySQL数据类型:底层原理、越界测试与最佳实践
linux·开发语言·数据库·c++·mysql