vue3更新的setup語法糖實例詳解
更新時間:2022年04月22日 16:58:51 作者:知有
vue3上線已經(jīng)很久了,許多小伙伴應該都已經(jīng)使用過vue3了,下面這篇文章主要給大家介紹了關于vue3更新的setup語法糖的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
前言
vue3最近更新了一個setup語法糖,這兩天才看到,使用起來雀食很甜,特發(fā)個帖子記錄下
語法糖用法:
// 將 `setup` attribute 添加到 `<script>` 代碼塊上 // 里面的代碼會被編譯成組件 `setup()` 函數(shù)的內(nèi)容 // 就是這么簡單明了 <script setup> </script>
語法糖帶來的體驗
一、組件自動注冊
// 無需使用components,引入即注冊,起飛有沒有 <script setup> import MyComponent from './MyComponent.vue' </script> <template> <MyComponent /> </template>
二、屬性及方法無需return
// 當使用 `<script setup>` 的時候,任何在 `<script setup>` 聲明的頂層的綁定 // (包括變量,函數(shù)聲明,以及 import 引入的內(nèi)容) 都能在模板中直接使用 import { ref } from 'vue' <script setup> // 變量 let msg = ref('Hello!') // 函數(shù) function log() { msg.value = "World!"; console.log(msg) } </script> <template> <div @click="log">{{ msg }}</div> </template>
三、自動將文件名定義為組件的name屬性
語法糖提供的API
在 <script setup> 中必須使用 defineProps 和 defineEmits API 來聲明 props 和 emits
1、defineProps
<script setup> const props = defineProps({ foo: String }) </script>
2、defineEmits
<script setup> const emit = defineEmits(['change', 'delete']) // emit('change', '1111') </script>
3、defineExpose
如果在父組件中通過ref='xxx’的方法來獲取子組件實例, 而且子組件使用了<script setup>, 則子組件的數(shù)據(jù)需要用defineExpose 的方式導出,否則不會暴露其屬性
<script setup> import { ref } from 'vue' const a = 1 const b = ref(2) defineExpose({ a, b }) </script>
<script setup>可以與普通的 <script> 一起使用
<script> // 普通 <script>, 在模塊范圍下執(zhí)行(只執(zhí)行一次) // 聲明額外的選項、例如自定義組件名 export default { name: '組件1' } </script> <script setup> // code </script>
總結
到此這篇關于vue3更新的setup語法糖的文章就介紹到這了,更多相關vue3 setup語法糖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!