刷刷题43 (Vue3 语法糖(<script setup>)与传统写法对比及示例)

一、基础结构差异

1. 组件注册

  • 语法糖‌:无需手动注册组件,直接引入即可使用‌
xml 复制代码
<script setup>
import ChildComponent from './Child.vue'
</script>

传统写法 ‌:需在 components 选项中显式注册‌

xml 复制代码
<script>
import ChildComponent from './Child.vue'
export default {
  components: { ChildComponent }
}
</script>
markdown 复制代码
#### 二、Props/Emits 处理

‌**2. 接收 Props**‌

-   ‌**语法糖**‌:通过 `defineProps` 宏直接声明‌

传统写法 ‌:通过 setup 函数参数接收‌

xml 复制代码
<script>
export default {
  props: ['msg'],
  setup(props) {
    // 使用 props.msg
  }
}
</script>

3. 触发事件

  • 语法糖 ‌:通过 defineEmits 定义事件‌
xml 复制代码
<script setup>
const emit = defineEmits(['update:value'])
emit('update:value', newValue)
</script>

传统写法 ‌:通过 setup 第二个参数 context 触发‌

xml 复制代码
<script>
export default {
  setup(props, { emit }) {
    emit('update:value', newValue)
  }
}
</script>

三、暴露方法/属性

4. 子组件暴露内容

  • 语法糖 ‌:使用 defineExpose 显式暴露‌
xml 复制代码
<script setup>
const childMethod = () => { /* ... */ }
defineExpose({ childMethod })
</script>

传统写法 ‌:通过 returnexpose 选项暴露‌

xml 复制代码
<script>
export default {
  setup() {
    const childMethod = () => { /* ... */ }
    return { childMethod } // 或使用 expose 选项
  }
}
</script>

四、代码简洁性对比

5. 代码结构简化

  • 语法糖 ‌:省去 export defaultsetup 函数和 return 语句‌
xml 复制代码
<script setup>
const count = ref(0)
</script>

传统写法‌:需完整结构‌2

xml 复制代码
<script>
export default {
  setup() {
    const count = ref(0)
    return { count }
  }
}
</script>

五、性能与开发体验

  • 编译优化‌:语法糖在编译阶段直接生成更高效的代码,减少运行时开销‌
  • 类型推导‌:语法糖支持更好的 TypeScript 类型推断‌
  • 生命周期 ‌:两者均支持组合式 API 生命周期钩子(如 onMounted)‌
相关推荐
前端炒粉几秒前
React 面试高频题
前端·react.js·面试
程序员陆业聪2 分钟前
让 Android 里的 AI 真正「干活」:Function Calling 工程实现全解
前端
mumuWorld4 分钟前
解决openclaw以及插件安装的报错
前端·ai编程
GISer_Jing4 分钟前
前端组件库——shadcn/ui:轻量、自由、可拥有,解锁前端组件库的AI时代未来
前端·人工智能·ui
执行部之龙8 分钟前
JS手写——call bind apply
前端·javascript
京东零售技术10 分钟前
告别手动搬砖: JoyCode + i18n-mcp 实现前端项目多语言自动化
前端
李少兄10 分钟前
企业资源计划(ERP)系统全景指南
java·前端·数据库·erp
阿里巴巴业务中台前端10 分钟前
[淘天校招]2026年校园招聘开启
面试
张一凡9314 分钟前
React 项目也能用依赖注入?我尝试了一下,真香
前端·react.js
somebody14 分钟前
零经验学 react 的第15天 - 过渡动画(使用 react-transition-group 库进行实现)
前端