前端培训:Vue3语法糖详解分享

215 阅读1分钟

script setup 有哪些优势

是在单文件组件(SFC)中使用组合式 API 的编译时语法糖。相比于普通的

 

  • 更少的样板内容,更简洁的代码。
  • 能够使用纯Typescript声明 props 和抛出事件。
  • 更好的运行时性能 (其模板会被编译成与其同一作用域的渲染函数,没有任何的中间代理)。
  • 更好的 IDE 类型推断性能 (减少语言服务器从代码中抽离类型的工作)。

基本语法

是 vue3 的一个新的语法糖,用起来特别简单。前端培训只需要在 script 标签中加上 setup 关键字。

中声明的函数变量以及import引入的内容、组件都能在模板中直接使用:

响应式

响应式状态需要明确使用响应式 APIs 来创建。和从 setup() 函数中返回值一样,ref 值在模板中使用的时候会自动解包:

动态组件

setup script 中要使用动态组件的时候,用动态的 :is 来绑定:

效果如下:

 

组件数据传递(props 和 emits)

中必须使用 definePropsdefineEmits API 来声明 props 和 emits ,web前端培训它们具备完整的类型推断并且在 中是直接可用的

定义组件的 props

通过defineProps指定当前 props 类型,获得上下文的 props 对象。示例:

定义组件的 emits

使用defineEmit定义当前组件含有的事件,并通过返回的上下文去执行 emit。示例:

父组件:

子组件:

效果如下:

 

对外暴露属性(defineExpose)

的组件默认不会对外部暴露任何内部声明的属性。如果有部分属性要暴露出去,可以使用 defineExpose

说白了就是暴露属性给外部使用

父组件:

子组件:

效果如下:

 

注意:defineProps、defineEmits、defineEmits API 不需要引入可以直接使用

获取 slots 和 attrs

注:useContext API 被弃用,取而代之的是更加细分的 api: useSlots 和 useAttrs。

使用 slots 和 attrs 的情况应该是很罕见的,因为可以在模板中通过 slotsslots** 和 **attrs 来访问它们。在你的确需要使用它们的罕见场景中,可以分别用 useSlotsuseAttrs 两个辅助函数:

useSlotsuseAttrs 是真实的运行时函数,它会返回与 setupContext.slotssetupContext.attrs 等价的值,同样也能在普通的组合式 API 中使用

创建异步 setup 方法(顶层 await)

语法的另一个很酷的功能是创建异步 setup 非常容易。这对于在创建组件时加载api,甚至将代码绑定到 功能很有用。

我们所要做的就是让我们的 setup 函数是异步的,在我们的 中使用一个顶级的await

中可以使用顶层 await。结果代码会被编译成 async setup()

例如,如果我们使用的是 Fetch API,我们可以像这样使用 await:

这样setup()函数将是异步的。

文章来源于前端工匠