vue3函數setUp和reactive函數詳細講解


1 setUp的執行時機

我們都知道,現在vue3是可以正常去使用methods的。
但是我們卻不可以在setUp中去調用methods中的方法。
為什么了???
我們先了解一下下面這兩個生命周期函數,分別是:
beforeCreate 表示data 中的數據還沒有初始化,是不可以使用的
Created : data已經被初始化了,可以使用
setUp這個生命周期發生在beforeCreate和created之前的。
是不是就知道為啥setUp中不可以去調用methods中的方法了。

2.setUp中無法使用data中的數據和調用methods的方法

<script>
export default {
  name: 'App',
  data:function(){
    return {
      mess:"我是data"
    }
  },
  methods:{
    func(){
      console.log("methods中的func")
    },
  },
  setup(){
    console.log('this',this);//undefined
    this.func();//無法調用的哈
  },
}
</script>

3.setUp函數的注意點

(1)由於我們不能夠在setUp函數中使用data和methods.
所以vue為了避免我們的錯誤使用,直接將setUp函數中的this
修改成為了undefined

(2) setUp函數只能夠數同步的,不能夠是異步的哈。
就是說你不能夠這樣操作
async setup(){
   
},
這樣會導致界面空白哈

4 Vue3中的reactive

在Vue2中響應式數據是通過de fineProperty來實現的.
而在Vue3中響應式數據是通過ES6的Proxy來實現的

reactive需要的注意點
reactive參數必須是對象(json/arr)
如果給reactive傳遞了其它對象
默認情況下修改對象,界面不會自動更新
如果想更新,可以通過重新賦值的方式

5 reactive傳入字符串數據不跟新

<template>
 <div>
    <div>
      <li>{{str}}</li>
      <button @click="func1">按鈕</button>
    </div>
 </div>
</template>
<script>
import {reactive} from 'vue'
export default {
  name: 'App',
   setup(){
    //  reactive 的本質就是傳入的數據包裝成一個proxy對象
    // 由於在創建的時候,傳遞的不是一個對象,那么將不會實現響應式。
    let str=reactive(123)
    function func1(){
      console.log(str);//123
      str=666;
    }
    return {str,func1 }
  },
}
</script>

我們發現點擊按鈕的時候,視圖並沒有更新。
因為我們傳不是一個對象.如果想跟新視圖。
應該使用ref函數

6 reactive傳入數組

<template>
 <div>
    <div>
      <li>{{arr}}</li>
      <button @click="func1">按鈕</button>
    </div>
 </div>
</template>
<script>
import {reactive} from 'vue'
export default {
  name: 'App',
   setup(){
    let arr=reactive([{name:'張三',age:19},{name:'李四',age:39}])
    function func1(){
      arr[0].name="我是張三的哥哥"
    }
    return {arr,func1 }
  },
}
</script>

7 reactive傳入其他對象的跟新方式

<template>
 <div>
    <div>
      <li>{{sate.time}}</li>
      <button @click="func1">按鈕</button>
    </div>
 </div>
</template>
<script>
import {reactive} from 'vue'
export default {
  name: 'App',
   setup(){
    let  sate=reactive({
      time:new Date()
    })
    function func1(){
      //傳入的是其他對象,直接跟新
      sate.time="2021年-6月-9日";
    }
    return {sate,func1 }
  },
}
</script>
如果你覺得我寫的還不錯的話
請我幫我點擊一個推薦
這是我寫下去的動力
如果有不清楚不明白的地方,歡迎評論!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM