刷刷题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)‌
相关推荐
想吃火锅10055 小时前
【leetcode】405.数字转换为十六进制数js
开发语言·javascript·ecmascript
程序员二叉5 小时前
【Java】集合面试全套精讲|HashMap/ArrayList高频考点完整版
java·面试·哈希算法
原则猫7 小时前
HOOKS 背后机制
前端
码语智行7 小时前
首页导航跳转功能深度解析-系统内和系统外
前端
不懂数据的小白7 小时前
面试题一:【三】AB实验入门(验证)
面试
阿猫的故乡7 小时前
Vue过渡动画从入门到装X:淡入淡出、滑动、列表动画、第三方库全搞定
前端·javascript·vue.js
我叫黑大帅7 小时前
通过php 中的Route:: 的写法了解什么是静态类调用
后端·面试·php
IManiy8 小时前
总结之Vibe Coding前端骨架
前端
小和尚敲木头8 小时前
vue3 vite动态拼接图片路径
javascript
JS菌8 小时前
AI Agent 沙箱双层防护体系:从权限过滤到内核隔离的完整实现
前端·人工智能·后端