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 {}
```**
相关推荐
2401_8784545328 分钟前
HTML和CSS的复习2
前端·css·html
We་ct36 分钟前
吃透现代CSS全技术体系
前端·css·css3·sass·postcss·预处理器
ZC跨境爬虫37 分钟前
跟着 MDN 学 HTML day_11:(语义化容器全站重构+独立CSS拆分+字体合规引入)
前端·css·ui·重构·html·edge浏览器
ZC跨境爬虫39 分钟前
跟着 MDN 学 HTML day_10:(超链接核心语法+路径规则)
前端·css·笔记·ui·html·edge浏览器
GISer_Jing42 分钟前
AI原生前端工程化进阶实践:从流式交互架构到端云协同全链路落地
前端·人工智能·后端·学习
被考核重击1 小时前
Vue响应式原理(下)
前端·javascript·vue.js
ZC跨境爬虫9 小时前
跟着 MDN 学 HTML day_9:(信件语义标记)
前端·css·笔记·ui·html
前端老石人9 小时前
HTML 字符引用完全指南
开发语言·前端·html
幼儿园技术家10 小时前
前端如何设计权限系统(RBAC / ABAC)?
前端
前端摸鱼匠11 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript