vue3更新的setup語法糖實例詳解
更新時間:2022年04月22日 16:58:51 作者:知有
vue3上線已經很久了,許多小伙伴應該都已經使用過vue3了,下面這篇文章主要給大家介紹了關于vue3更新的setup語法糖的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
前言
vue3最近更新了一個setup語法糖,這兩天才看到,使用起來雀食很甜,特發(fā)個帖子記錄下
語法糖用法:
// 將 `setup` attribute 添加到 `<script>` 代碼塊上 // 里面的代碼會被編譯成組件 `setup()` 函數(shù)的內容 // 就是這么簡單明了 <script setup> </script>
語法糖帶來的體驗
一、組件自動注冊
// 無需使用components,引入即注冊,起飛有沒有
<script setup>
import MyComponent from './MyComponent.vue'
</script>
<template>
<MyComponent />
</template>二、屬性及方法無需return
// 當使用 `<script setup>` 的時候,任何在 `<script setup>` 聲明的頂層的綁定
// (包括變量,函數(shù)聲明,以及 import 引入的內容) 都能在模板中直接使用
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ù)據需要用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語法糖內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

