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 的方式導(dǎo)出,否則不會暴露其屬性
<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>總結(jié)
到此這篇關(guān)于vue3更新的setup語法糖的文章就介紹到這了,更多相關(guān)vue3 setup語法糖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue3 攜帶參數(shù)跳轉(zhuǎn)|router傳參方式
這篇文章主要介紹了vue3 攜帶參數(shù)跳轉(zhuǎn)|router傳參方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06
vue使用自定義指令實現(xiàn)按鈕權(quán)限展示功能
這篇文章主要介紹了vue中使用自定義指令實現(xiàn)按鈕權(quán)限展示功能,本文結(jié)合實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-04-04

