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

詳解vue3中setUp和reactive函數(shù)的用法

 更新時(shí)間:2021年06月10日 08:27:39   作者:平凡是最美蕩氣回腸  
這篇文章主要介紹了vue3函數(shù)setUp和reactive函數(shù)的相關(guān)知識及setup函數(shù)和reactive函數(shù)的注意點(diǎn),通過具體代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下

1 setUp的執(zhí)行時(shí)機(jī)

我們都知道,現(xiàn)在vue3是可以正常去使用methods的。
但是我們卻不可以在setUp中去調(diào)用methods中的方法。
為什么了???
我們先了解一下下面這兩個(gè)生命周期函數(shù),分別是:
beforeCreate 表示data 中的數(shù)據(jù)還沒有初始化,是不可以使用的
Created : data已經(jīng)被初始化了,可以使用
setUp在beforeCreate 和 Created 這兩個(gè)函數(shù)之間。
是不是就知道為啥setUp中不可以去調(diào)用methods中的方法了。

2.setUp中無法使用data中的數(shù)據(jù)和調(diào)用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();//無法調(diào)用的哈
  },
}
</script>

3.setUp函數(shù)的注意點(diǎn)

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

(2) setUp函數(shù)只能夠數(shù)同步的,不能夠是異步的哈。

就是說你不能夠這樣操作
async setup(){
  
},
這樣會導(dǎo)致界面空白哈

4 Vue3中的reactive

在Vue2中響應(yīng)式數(shù)據(jù)是通過de fineProperty來實(shí)現(xiàn)的.
而在Vue3中響應(yīng)式數(shù)據(jù)是通過ES6的Proxy來實(shí)現(xiàn)的

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

5 reactive傳入字符串?dāng)?shù)據(jù)不跟新

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

我們發(fā)現(xiàn)點(diǎn)擊按鈕的時(shí)候,視圖并沒有更新。
因?yàn)槲覀儌鞑皇且粋€(gè)對象.如果想跟新視圖。
應(yīng)該使用ref函數(shù)

6 reactive傳入數(shù)組

<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>

以上就是vue3 setUp和reactive函數(shù)詳細(xì)講解的詳細(xì)內(nèi)容,更多關(guān)于vue3 setUp和reactive函數(shù)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue-router 類似Vuex實(shí)現(xiàn)組件化開發(fā)的示例

    Vue-router 類似Vuex實(shí)現(xiàn)組件化開發(fā)的示例

    本篇文章主要介紹了Vue-router 類似Vuex實(shí)現(xiàn)組件化開發(fā)的示例,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-09-09
  • Vue 應(yīng)用中結(jié)合vux使用微信 jssdk的方法

    Vue 應(yīng)用中結(jié)合vux使用微信 jssdk的方法

    今天小編就為大家分享一篇Vue 應(yīng)用中結(jié)合vux使用微信 jssdk的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • vue自定義組件實(shí)現(xiàn)雙向綁定

    vue自定義組件實(shí)現(xiàn)雙向綁定

    這篇文章主要為大家詳細(xì)介紹了vue自定義組件實(shí)現(xiàn)雙向綁定,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • Django+Vue.js實(shí)現(xiàn)搜索功能

    Django+Vue.js實(shí)現(xiàn)搜索功能

    本文主要介紹了Django+Vue.js實(shí)現(xiàn)搜索功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-06-06
  • vue中如何修改props傳進(jìn)來的值

    vue中如何修改props傳進(jìn)來的值

    大家應(yīng)該都知道vue是單向數(shù)據(jù)流,一般我們也不會在子組件里面修改父組件傳進(jìn)來的值,但總有需要修改的時(shí)候,這篇文章主要介紹了vue中修改props傳進(jìn)來的值,需要的朋友可以參考下
    2022-12-12
  • vue3.0路由自動導(dǎo)入的方法實(shí)例

    vue3.0路由自動導(dǎo)入的方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于vue3.0路由自動導(dǎo)入的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Vue引入使用localforage改進(jìn)本地離線存儲方式(突破5M限制)

    Vue引入使用localforage改進(jìn)本地離線存儲方式(突破5M限制)

    這篇文章主要介紹了Vue引入使用localforage改進(jìn)本地離線存儲方式(突破5M限制),具有很好的參考價(jià)值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 基于Vue+Echart繪制動態(tài)圖

    基于Vue+Echart繪制動態(tài)圖

    這篇文章主要給大家介紹了基于Vue+Echart的動態(tài)圖繪制,用戶需要展示他的數(shù)據(jù)庫是有哪個(gè)數(shù)據(jù)庫轉(zhuǎn)化的,需要展示數(shù)據(jù)庫的軌跡圖,前導(dǎo)庫的關(guān)系圖,文中有詳細(xì)的實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2023-10-10
  • Vue引入并使用Element組件庫的兩種方式小結(jié)

    Vue引入并使用Element組件庫的兩種方式小結(jié)

    本文主要介紹了Vue引入并使用Element組件庫的兩種方式小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • vue3.0搭配.net core實(shí)現(xiàn)文件上傳組件

    vue3.0搭配.net core實(shí)現(xiàn)文件上傳組件

    這篇文章主要介紹了vue3.0搭配.net core實(shí)現(xiàn)文件上傳組件,幫助大家開發(fā)Web應(yīng)用程序,完成需求,感興趣的朋友可以了解下
    2020-10-10

最新評論