Vue3?setup的注意點(diǎn)及watch的監(jiān)視屬性有哪些

本文小編為大家詳細(xì)介紹“Vue3 setup的注意點(diǎn)及watch的監(jiān)視屬性有哪些”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Vue3 setup的注意點(diǎn)及watch的監(jiān)視屬性有哪些”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來(lái)學(xué)習(xí)新知識(shí)吧。

專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)武陟免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了1000多家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

一,setup須知

1.1setup的執(zhí)行時(shí)間

1.setup的執(zhí)行時(shí)間要比beforCreate執(zhí)行要早

Vue3?setup的注意點(diǎn)及watch的監(jiān)視屬性有哪些

  export default {
    name: "Demo",
    beforeCreate(){
      console.log('beforeCreate已執(zhí)行');
    },
    setup() {
      console.log('setup已執(zhí)行');
      let person = reactive({
        name: "小明",
        age: 20,
      });
      return {
        person,
      };
    },
  };
1.2.steup參數(shù)

setup的參數(shù)
1.props: 值為對(duì)象,包含: 組件外部傳遞過(guò)來(lái),且組件內(nèi)部聲明接收了的屬性

2.context:上下文對(duì)象
①attrs:值為對(duì)象,包含: 組件外部傳遞過(guò)來(lái),但沒(méi)有在props配置中聲明的屬性,相當(dāng)于 this.$attrs

  export default {
    name: "Demo",
    props:['msg','age'],
    setup(props) {
      console.log(props);
      let person = reactive({
        name: "小明",
        age: 20,
      });   
      return {
        person,
      };
    },
  };

Vue3?setup的注意點(diǎn)及watch的監(jiān)視屬性有哪些

②slots: 收到的插槽內(nèi)容,相當(dāng)于 this.$slots。

在App中定義插槽

<template v-slot:qwe>
<span>123</span>
</template>
<template v-slot:ewq>
<span>321</span>
</template>

在子組件中獲取到插槽

 console.log(context.slots); // 得到插槽

Vue3?setup的注意點(diǎn)及watch的監(jiān)視屬性有哪些

③emit: 分發(fā)自定義事件的函數(shù),相當(dāng)于 this.$emit。

在App中寫(xiě)一個(gè)自定義事件并且傳給組件

<Demo @hi="Hello" msg="山魚(yú)" age=10>
</Demo>
  setup() {
    function Hello(){
      console.log('你好!');
    }
    return {
      Hello
    }
  }

然后去到子組件使用context.comit獲取到自定義事件

Vue3?setup的注意點(diǎn)及watch的監(jiān)視屬性有哪些

 function point(){
        context.emit('hi',666)
      }     
5TgxPT2v-1681788304084)]

```js
 function point(){
        context.emit('hi',666)
      }

與Vue2中的computed配置功能一致

import { reactive,computed} from "vue";
  export default {
    name: "Demo",
    setup() {
      let person = reactive({
        firstName: "小",
        lastName: "明",
      }); 
      // 計(jì)算屬性的簡(jiǎn)寫(xiě)形式,不考慮修改,是只讀的
      /*person.fullName= computed(()=>{
        return person.firstName+'-'+person.lastName
      }) */
      // 計(jì)算屬性的完整形式(可以讀改)
      person.fullName= computed({
        get(){
          return person.firstName +'-'+person.lastName
        },
        set(value){
          const arr = value.split('-')
          person.firstName = arr[0]
          person.lastName = arr[1]
        }
      })
      return {
        person,
      };
    },
  };

二,watch監(jiān)視屬性

有兩種watch,分別是單個(gè)屬性數(shù)據(jù)監(jiān)視,和多個(gè)屬性數(shù)據(jù)監(jiān)視

watch中的三個(gè)參數(shù)分別為,監(jiān)視的對(duì)象,監(jiān)視的函數(shù),監(jiān)視屬性的配置

監(jiān)視r(shí)ef所定義的數(shù)據(jù)

①監(jiān)視屬性監(jiān)視r(shí)ef的一個(gè)響應(yīng)式的值

    watch(sum, (newvalue, oldvalue) => {
      console.log('當(dāng)前值為'+newvalue, '以前值為'+oldvalue);
    });

②監(jiān)視r(shí)ef所定義的多個(gè)響應(yīng)式數(shù)據(jù)

        watch([sum,msg], (newvalue, oldvalue) => {
      console.log('當(dāng)前值為'+newvalue, '以前值為'+oldvalue);
    });

監(jiān)視r(shí)eactive所定義的數(shù)據(jù)

①監(jiān)視r(shí)eactive定義的數(shù)據(jù)的變化

使用reactive定義的數(shù)據(jù)無(wú)法使用watch正確的獲取newValue
并且會(huì)強(qiáng)制開(kāi)啟深度監(jiān)視

             watch(person,(newValue, oldValue) => {
                console.log('person變化了',newValue,oldValue)
             })

②監(jiān)視r(shí)eactive所定義的響應(yīng)式數(shù)據(jù)的某個(gè)屬性

            watch(()=>person.name,(newValue,oldValue)=>{
               console.log('person.name發(fā)生了變化',newValue,oldValue)
           })

③監(jiān)視r(shí)eactive所定義的響應(yīng)式數(shù)據(jù)的某些屬性

watch([()=>{person.age},()=>{person.name}],(newValue,oldValue)=>{
                console.log('person.name發(fā)生了變化',newValue,oldValue)
            })

④特殊形況

注:該情況監(jiān)視的是recative所定義的對(duì)象中的某個(gè)屬性,所以deep可以開(kāi)啟

 watch(()=>person.job,(newValue,oldValue)=>{
                console.log('person.name發(fā)生了變化',newValue,oldValue)
            }, {deep: true})

讀到這里,這篇“Vue3 setup的注意點(diǎn)及watch的監(jiān)視屬性有哪些”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過(guò)才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)頁(yè)題目:Vue3?setup的注意點(diǎn)及watch的監(jiān)視屬性有哪些
轉(zhuǎn)載來(lái)于:http://muchs.cn/article48/johihp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)建站公司、響應(yīng)式網(wǎng)站、微信小程序、網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化