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

Vue3中的setup執(zhí)行時機與注意點說明

 更新時間:2022年07月02日 10:07:25   作者:山竹回家了  
這篇文章主要介紹了Vue3中的setup執(zhí)行時機與注意點說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

setup執(zhí)行時機與注意點

setup執(zhí)行時機在beforeCreate之前

在setup中是不能使用data和methods,因為還沒初始化好

由于不能再setup函數中使用data和methods,所以Vue為了避免我們錯誤的使用,它直接將setup函數中的this修改成undefined.

setup只能同步,不能異步

Vue3.0 setup()函數用法

setup()函數作為在組件內部使用組合API的入口點

setup()函數在初始的prop解析后,組件實例創(chuàng)建之前被調用。對于組件的生命周期鉤子,setup()函數在beforeCreate鉤子之前調用。

如果setup()函數返回一個對象,該對象上的屬性將被合并到組件模板的渲染上下文中。如:

setup() {
? // 為目標對象創(chuàng)建一個響應式對象
? const state = Vue.reactive((count: 0})
? function increment() {
? ? state.count++
? }
// 返回一個對象,該對象上的屬性可以在模板中使用
? return {
? ? state,
? ? increment
? }
}

setup()函數返回的對象有兩個屬性

一個是響應式對象(即為原始對象創(chuàng)建的代理對象),另一個是函數。在DOM模板中,可以世界使用這兩屬性,如:

<view @click="addClick">count值:{{state.count}}</view>

setup()函數可以接收兩個可選的參數

第一個是已解析的props。通過該參數可以訪問在props選項中定義的prop,如:

app.component('ButtonItem', {
? props: ['buttonTitle'],
? setup(props) {
? ?console.log(props.buttonTitle)?
? }
})

setup()函數接收的第二個可選的參數是一個context對象

該對象是一個普通的JavaScript對象,不是響應式的,可以完全的使用ES6的對象解構語法對context進行解構,另外還公開了3個組件屬性,如:

const component = {
? setup(props, context) {
? ? // 屬性(非響應式對象)
? ? console.log(context.attrs)
? ? // 插槽(非響應式對象)
? ? console.log(context.slots)
? ? // 發(fā)出的事件(方法)
? ? console.log(context.emit)
? }
}

當setup()和選項API一起使用

在setup()函數內部不要使用this,因為setup()函數是在選項被解析之前調用的,在setup()函數內不能訪問data、computed和methods組件選項。如下代碼是錯誤范例:

setup() {
? function onClick() {
? ? ? console.log(this) // 并不是預期的this
? }
}

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 詳解Vue.js自定義tipOnce指令用法實例

    詳解Vue.js自定義tipOnce指令用法實例

    這篇文章主要介紹了詳解Vue.js自定義tipOnce指令用法實例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • vue前端如何接收后端傳過來的帶list集合的數據

    vue前端如何接收后端傳過來的帶list集合的數據

    這篇文章主要介紹了vue前端如何接收后端傳過來的帶list集合的數據,前后端交互,文中的示例Json報文,前端采用vue進行接收,本文結合實例代碼給大家介紹的非常詳細,感興趣的朋友一起看看吧
    2024-02-02
  • Vue3異步數據加載組件suspense的使用方法

    Vue3異步數據加載組件suspense的使用方法

    前端開發(fā)中異步請求是非常常見的事情,比如遠程讀取圖片,調用后端接口等等,這篇文章主要給大家介紹了關于Vue3異步數據加載組件suspense的使用方法,suspense中文含義是懸念的意思,需要的朋友可以參考下
    2021-08-08
  • 解決Vue數據更新了但頁面沒有更新的問題

    解決Vue數據更新了但頁面沒有更新的問題

    在vue項目中,有些我們會遇到修改完數據,但是視圖卻沒有更新的情況,具體的場景不一樣,解決問題的方法也不一樣,在網上看了很多文章,在此總結匯總一下,需要的朋友可以參考下
    2023-08-08
  • Vue3中props和emit的使用方法詳解

    Vue3中props和emit的使用方法詳解

    props是Vue中最常見的父子通信方式,使用起來也比較簡單,下面這篇文章主要給大家介紹了關于Vue3中props和emit的使用方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-03-03
  • vue 頁面加載進度條組件實例

    vue 頁面加載進度條組件實例

    下面小編就為大家分享一篇vue 頁面加載進度條組件實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • vue項目實現分頁效果

    vue項目實現分頁效果

    這篇文章主要為大家詳細介紹了vue項目實現分頁效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • Vue表單驗證?trigger:'blur'OR?trigger:'change'區(qū)別解析

    Vue表單驗證?trigger:'blur'OR?trigger:'change&ap

    利用?elementUI?實現表單元素校驗時,出現下拉框內容選中后校驗不消失的異常校驗情形,這篇文章主要介紹了Vue表單驗證?trigger:‘blur‘?OR?trigger:‘change‘?區(qū)別,需要的朋友可以參考下
    2023-09-09
  • vue打包通過image-webpack-loader插件對圖片壓縮優(yōu)化操作

    vue打包通過image-webpack-loader插件對圖片壓縮優(yōu)化操作

    這篇文章主要介紹了vue打包通過image-webpack-loader插件對圖片壓縮優(yōu)化操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • vue中使用moment設置倒計時的方法

    vue中使用moment設置倒計時的方法

    這篇文章給大家介紹了vue中使用moment設置倒計時的方法,文中通過代碼示例給大家介紹的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下
    2024-02-02

最新評論