欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3中單文件組件<script?setup>實例詳解

 更新時間:2022年07月24日 15:17:46   作者:丑小鴨變黑天鵝  
<script?setup>是vue3中新引入的語法糖,目的是簡化使用Composition?API時冗長的模板代碼,下面這篇文章主要給大家介紹了關(guān)于vue3中單文件組件<script?setup>的相關(guān)資料,需要的朋友可以參考下

一、相比普通script語法的優(yōu)勢

<script setup>是在單文件組件 (SFC) 中使用組合式 API的編譯時語法糖。相比于普通的 <script> 語法,它具有更多優(yōu)勢

  • 更少的樣板內(nèi)容,更簡潔的代碼
  • 能夠使用純 Typescript 聲明 props 和拋出事件。
  • 更好的運行時性能 (其模板會被編譯成與其同一作用域的渲染函數(shù),沒有任何的中間代理)。
  • 更好的 IDE 類型推斷性能 (減少語言服務(wù)器從代碼中抽離類型的工作)。

二、基本語法

要使用這個語法,需要將 setup attribute 添加到 <script> 代碼塊上

<script setup>
    console.log('hello script setup')
</script>

里面的代碼會被編譯成組件 setup() 函數(shù)的內(nèi)容。這意味著與普通的 <script> 只在組件被首次引入的時候執(zhí)行一次不同,<script setup>中的代碼會在每次組件實例被創(chuàng)建的時候執(zhí)行。

頂層的綁定會被暴露給模板

當使用 <script setup> 的時候,任何在 <script setup> 聲明的頂層的綁定 (包括變量,函數(shù)聲明,以及 import 引入的內(nèi)容) 都能在模板中直接使用

<script setup>
// 變量
const msg = 'Hello!'

// 函數(shù)
function log() {
  console.log(msg)
}
</script>

<template>
  <div @click="log">{{ msg }}</div>
</template>

import 導(dǎo)入的內(nèi)容也會以同樣的方式暴露。意味著可以在模板表達式中直接使用導(dǎo)入的 helper 函數(shù),并不需要通過 methods 選項來暴露它:

<script setup>
import { capitalize } from './helpers'
</script>

<template>
  <div>{{ capitalize('hello') }}</div>
</template>

三、響應(yīng)式

響應(yīng)式狀態(tài)需要明確使用響應(yīng)式 APIs 來創(chuàng)建。和從 setup() 函數(shù)中返回值一樣,ref 值在模板中使用的時候會自動解包:

<script setup>
import { ref } from 'vue'

const count = ref(0)
</script>

<template>
  <button @click="count++">{{ count }}</button>
</template>

四、使用組件

<script setup>范圍里的值也能被直接作為自定義組件的標簽名使用:

<script setup>
import MyComponent from './MyComponent.vue'
</script>

<template>
  <MyComponent />
</template>

動態(tài)組件

由于組件被引用為變量而不是作為字符串鍵來注冊的,在 <script setup> 中要使用動態(tài)組件的時候,就應(yīng)該使用動態(tài)的:is來綁定

<script setup>
import Foo from './Foo.vue'
import Bar from './Bar.vue'
</script>

<template>
  <component :is="Foo" />
  <component :is="someCondition ? Foo : Bar" />
</template>

遞歸組件

  • 一個單文件組件可以通過它的文件名被其自己所引用。例如:名為 FooBar.vue 的組件可以在其模板中用 <FooBar/> 引用它自己。
  • 請注意這種方式相比于 import 導(dǎo)入的組件優(yōu)先級更低。如果有命名的 import 導(dǎo)入和組件的推斷名沖突了,可以使用 import 別名導(dǎo)入:
import { FooBar as FooBarChild } from './components'

命名空間組件

  • 可以使用帶點的組件標記,例如 <Foo.Bar>來引用嵌套在對象屬性中的組件。這在需要從單個文件中導(dǎo)入多個組件的時候非常有用:
<script setup>
import * as Form from './form-components'
</script>

<template>
  <Form.Input>
    <Form.Label>label</Form.Label>
  </Form.Input>
</template>

五、使用自定義指令

  • 全局注冊的自定義指令將以符合預(yù)期的方式工作,且本地注冊的指令可以直接在模板中使用,就像上文所提及的組件一樣。
  • 但這里有一個需要注意的限制:必須以 vNameOfDirective 的形式來命名本地自定義指令,以使得它們可以直接在模板中使用
<script setup>
const vMyDirective = {
  beforeMount: (el) => {
    // 在元素上做些操作
  }
}
</script>
<template>
  <h1 v-my-directive>This is a Heading</h1>
</template>
<script setup>
  // 導(dǎo)入的指令同樣能夠工作,并且能夠通過重命名來使其符合命名規(guī)范
  import { myDirective as vMyDirective } from './MyDirective.js'
</script>

六、defineProps 和 defineEmits

在 <script setup> 中必須使用 defineProps 和 defineEmits API 來聲明 props 和 emits ,它們具備完整的類型推斷并且在 <script setup> 中是直接可用的

<script setup>
const props = defineProps({
  foo: String
})

const emit = defineEmits(['change', 'delete'])
// setup code
</script>
  • defineProps 和 defineEmits 都是只在 <script setup> 中才能使用的編譯器宏。他們不需要導(dǎo)入且會隨著 <script setup> 處理過程一同被編譯掉。
  • defineProps 接收與 props 選項相同的值,defineEmits 也接收 emits 選項相同的值
  • defineProps 和 defineEmits 在選項傳入后,會提供恰當?shù)念愋屯茢?/li>
  • 傳入到 defineProps 和 defineEmits 的選項會從 setup 中提升到模塊的范圍。因此,傳入的選項不能引用在 setup 范圍中聲明的局部變量。這樣做會引起編譯錯誤。但是,它可以引用導(dǎo)入的綁定,因為它們也在模塊范圍內(nèi)

七、defineExpose

  • 使用 <script setup> 的組件是默認關(guān)閉的,也即通過模板 ref 或者 $parent 鏈獲取到的組件的公開實例,不會暴露任何在 <script setup> 中聲明的綁定。
  • 為了在 <script setup> 組件中明確要暴露出去的屬性,使用 defineExpose 編譯器宏
<script setup>
import { ref } from 'vue'

const a = 1
const b = ref(2)

defineExpose({
  a,
  b
})
</script>
  • 當父組件通過模板 ref 的方式獲取到當前組件的實例,獲取到的實例會像這樣 { a: number, b: number } (ref 會和在普通實例中一樣被自動解包)

八、useSlots 和 useAttrs

  • 在 <script setup> 使用 slots 和 attrs 的情況應(yīng)該是很罕見的,因為可以在模板中通過 $slots 和 $attrs 來訪問它們。在你的確需要使用它們的罕見場景中,可以分別用 useSlots 和 useAttrs 兩個輔助函數(shù)
<script setup>
import { useSlots, useAttrs } from 'vue'

const slots = useSlots()
const attrs = useAttrs()
</script>
  • useSlots 和 useAttrs 是真實的運行時函數(shù),它會返回與 setupContext.slots 和 setupContext.attrs 等價的值,同樣也能在普通的組合式 API 中使用。

九、頂層 await

<script setup> 中可以使用頂層 await。結(jié)果代碼會被編譯成 async setup()

<script setup>
const post = await fetch(`/api/post/1`).then(r => r.json())
</script>
  • 另外,await 的表達式會自動編譯成在 await 之后保留當前組件實例上下文的格式
  • 注意,async setup() 必須與 Suspense 組合使用,Suspense 目前還是處于實驗階段的特性

附:<script setup>和 <script>之間的主要區(qū)別

  • 性能
    <script setup>具有更好的運行時性能,因為它將模板編譯為具有相同作用域且沒有中間代理的呈現(xiàn)方法。<script>使用中間代理編譯模板。
  • 代碼語法
    在<script>塊中,我們需要導(dǎo)出帶有樣板代碼的模塊。<script setup>允許我們定義組件,而無需導(dǎo)出任何內(nèi)容。在<script setup>塊中,我們可以使用更少的樣板文件獲得更簡潔的代碼。
  • 執(zhí)行流程
    <script>塊在我們首次導(dǎo)入組件時執(zhí)行。<script setup>塊將在每次創(chuàng)建組件實例時執(zhí)行。
  • 組織代碼
    我們可以根據(jù)<script setup>塊中的業(yè)務(wù)邏輯來組織代碼。使用<script>塊是不可能的,因為我們必須遵循Vue的選項API或組合API的編碼結(jié)構(gòu)。

總結(jié)

到此這篇關(guān)于vue3中單文件組件&lt;script setup&gt;詳解的文章就介紹到這了,更多相關(guān)vue3單文件組件&lt;script setup&gt;內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue+element自定義查詢組件

    vue+element自定義查詢組件

    這篇文章主要為大家詳細介紹了vue+element自定義查詢組件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • clipboard在vue中的使用的方法示例

    clipboard在vue中的使用的方法示例

    這篇文章主要介紹了clipboard在vue中的使用的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • vue-quill-editor實現(xiàn)圖片上傳功能

    vue-quill-editor實現(xiàn)圖片上傳功能

    這篇文章主要為大家詳細介紹了vue-quill-editor實現(xiàn)圖片上傳功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • vue3配置全局參數(shù)(掛載全局方法)以及組件的使用

    vue3配置全局參數(shù)(掛載全局方法)以及組件的使用

    這篇文章主要介紹了vue3配置全局參數(shù)(掛載全局方法)以及組件的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue3調(diào)度器effect的scheduler功能實現(xiàn)詳解

    vue3調(diào)度器effect的scheduler功能實現(xiàn)詳解

    這篇文章主要為大家介紹了vue3調(diào)度器effect的scheduler功能實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • ruoyi-vue3 集成aj-captcha實現(xiàn)滑塊、文字點選驗證碼功能

    ruoyi-vue3 集成aj-captcha實現(xiàn)滑塊、文字點選驗證碼功能

    這篇文章主要介紹了 ruoyi-vue3 集成aj-captcha實現(xiàn)滑塊、文字點選驗證碼,本文基于后端RuoYi-Vue 3.8.7 和 前端 RuoYi-Vue3 3.8.7,集成以AJ-Captcha文字點選驗證碼為例,不需要鍵盤手動輸入,極大優(yōu)化了傳統(tǒng)驗證碼用戶體驗不佳的問題,感興趣的朋友一起看看吧
    2023-12-12
  • vue中實現(xiàn)動態(tài)生成二維碼的方法

    vue中實現(xiàn)動態(tài)生成二維碼的方法

    這篇文章主要介紹了vue中實現(xiàn)動態(tài)生成二維碼的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • 詳解Vue中watch的高級用法

    詳解Vue中watch的高級用法

    我們通過實例代碼給大家分享了Vue中watch的高級用法,對此知識點有需要的朋友可以跟著學(xué)習(xí)下。
    2018-05-05
  • vue列表自動滾動實例

    vue列表自動滾動實例

    這篇文章主要介紹了vue列表自動滾動實例代碼,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue2利用Axios發(fā)起請求的詳細過程記錄

    Vue2利用Axios發(fā)起請求的詳細過程記錄

    有很多時候你在構(gòu)建應(yīng)用時需要訪問一個API并展示其數(shù)據(jù),做這件事的方法有好幾種,而使用基于promise的HTTP客戶端axios則是其中非常流行的一種,這篇文章主要給大家介紹了關(guān)于Vue2利用Axios發(fā)起請求的詳細過程,需要的朋友可以參考下
    2021-12-12

最新評論