vue3 中,setup 函数 和 <script setup> 的区别

  • App.vue → 根组件
  • ChildSetup.vue → 用 setup 函数 的子组件
  • ChildScriptSetup.vue → 用 的子组件

**## 1. App.vue

js 复制代码
<template>
<div>
<h2>父组件</h2>
<ChildSetup ref="setupRef" />
<ChildScriptSetup ref="scriptSetupRef" />
</div>
</template>

<script setup>
import { onMounted, ref } from 'vue'
import ChildSetup from './ChildSetup.vue'
import ChildScriptSetup from './ChildScriptSetup.vue'

const setupRef = ref(null)
const scriptSetupRef = ref(null)

onMounted(() => {
console.log('setup 子组件实例:', setupRef.value)
console.log('script setup 子组件实例:', scriptSetupRef.value)
})
</script>

2. ChildSetup.vue(setup 函数写法)

js 复制代码
<template>
<div>
<h3>我是 setup 函数组件</h3>
<p>{{ msg }}</p>
<button @click="increase">count: {{ count }}</button>
</div>
</template>

<script>
import { ref } from 'vue'

export default {
name: 'ChildSetup',
setup(props, { expose }) {
const msg = 'Hello from setup()'
const count = ref(0)
function increase() {
count.value++
}

// 显式暴露出去
expose({ msg, count, increase })

return {
msg,
count,
increase,
}
}
}
</script>

3. ChildScriptSetup.vue

js 复制代码
<template>
<div>
<h3>我是 script setup 语法糖组件</h3>
<p>{{ msg }}</p>
<button @click="increase">count: {{ count }}</button>
</div>
</template>
<script setup>
import { ref } from 'vue'
const msg = 'Hello from <script setup>'
const count = ref(0)
function increase() {
count.value++
}
// 如果不写 defineExpose,默认不暴露任何东西
defineExpose({
msg,
count,
increase
})
</script>

运行效果

  1. 页面上能看到两个子组件,按钮点了都会加 1。
  2. 打开控制台,你会看到类似输出:
js 复制代码
setup 子组件实例: Proxy { msg: "Hello from setup()", count: RefImpl, increase: ƒ }
script setup 子组件实例: Proxy { msg: "Hello from <script setup>", count: RefImpl, increase: ƒ }

如果你把 ChildScriptSetup.vue 里的 defineExpose 删掉, 再看输出,会变成:

js 复制代码
script setup 子组件实例: Proxy {}
```**
相关推荐
却尘2 分钟前
Next.js 请求最佳实践 - vercel 2026一月发布指南
前端·react.js·next.js
ccnocare3 分钟前
浅浅看一下设计模式
前端
Lee川6 分钟前
🎬 从标签到屏幕:揭秘现代网页构建与适配之道
前端·面试
Ticnix33 分钟前
ECharts初始化、销毁、resize 适配组件封装(含完整封装代码)
前端·echarts
纯爱掌门人36 分钟前
终焉轮回里,藏着 AI 与人类的答案
前端·人工智能·aigc
twl40 分钟前
OpenClaw 深度技术解析
前端
崔庆才丨静觅43 分钟前
比官方便宜一半以上!Grok API 申请及使用
前端
星光不问赶路人1 小时前
vue3使用jsx语法详解
前端·vue.js
天蓝色的鱼鱼1 小时前
shadcn/ui,给你一个真正可控的UI组件库
前端
布列瑟农的星空1 小时前
前端都能看懂的Rust入门教程(三)——控制流语句
前端·后端·rust