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

淺析vue3響應(yīng)式數(shù)據(jù)與watch屬性

 更新時間:2022年05月24日 08:58:05   作者:鵬程933  
這篇文章主要介紹了vue3響應(yīng)式數(shù)據(jù)與watch屬性的相關(guān)知識,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
  1. 是Vue3的 composition API中2個最重要的響應(yīng)式API
  2. ref用來處理基本類型數(shù)據(jù), reactive用來處理對象(遞歸深度響應(yīng)式)
  3. 如果用ref對象/數(shù)組, 內(nèi)部會自動將對象/數(shù)組轉(zhuǎn)換為reactive的代理對象
  4. ref內(nèi)部: 通過給value屬性添加getter/setter來實現(xiàn)對數(shù)據(jù)的劫持
  5. reactive內(nèi)部: 通過使用Proxy來實現(xiàn)對對象內(nèi)部所有數(shù)據(jù)的劫持, 并通過Reflect操作對象內(nèi)部數(shù)據(jù)
  6. ref的數(shù)據(jù)操作: 在js中要.value, 在模板中不需要(內(nèi)部解析模板時會自動添加.value)
<template>
  <div>ref與</div>
  <div>msg1:{{msg1}}</div>
  <div>msg2:{{msg2}}</div>
  <div>msg3:{{msg3}}</div>
  <button @click="updata">改變</button>
</template>

<script lang="ts">
import {reactive, ref} from "vue";
export default {
  setup(){
    const msg1=ref('hello')
    const msg2 = reactive({
      name: 'jack',
      wife: {
        name:'rose'
      }
    })
    const msg3 = ref({ // ref中如果是一個對象,那么經(jīng)過了reactive處理,形成了Proxy對象
      name: 'jack',
      wife: {
        name: 'rose'
      }
    })
    function updata(){
      msg1.value += '++'
      msg2.wife.name += '++'
      msg3.value.wife.name += '++'
    }
    return {
      msg1,
      msg2,
      msg3,
      updata
    }
  }
}
</script>

計算屬性與監(jiān)視

computed函數(shù):

  • 與computed配置功能一致
  • 有g(shù)etter/setter

與watch配置功能一致

  • 監(jiān)視指定的一個或多個響應(yīng)式數(shù)據(jù), 一旦數(shù)據(jù)變化, 就自動執(zhí)行監(jiān)視回調(diào)
  • 默認(rèn)初始時不執(zhí)行回調(diào), 但可以通過配置immediate為true, 來指定初始時立即執(zhí)行第一次
  • 通過配置deep為true, 來指定深度監(jiān)視

watchEffect函數(shù)

  • 不用直接指定要監(jiān)視的數(shù)據(jù), 回調(diào)函數(shù)中使用的哪些響應(yīng)式數(shù)據(jù)就監(jiān)視哪些響應(yīng)式數(shù)據(jù)
  • 默認(rèn)初始時就會執(zhí)行第一次, 從而可以收集需要監(jiān)視的數(shù)據(jù)
  • 監(jiān)視數(shù)據(jù)發(fā)生變化時回調(diào)
<template>
  <h1>計算屬性與監(jiān)視</h1>
  <fieldset>
    <legend>姓名操作</legend>
    姓氏:<input type="text" placeholder="輸入姓氏" v-model="user.firstName"><br>
    名字:<input type="text" placeholder="輸入名字" v-model="user.lastName">
  </fieldset>
  <fieldset>
    <legend>計算屬性和監(jiān)視</legend>
    姓名:<input type="text" placeholder="顯示姓名" v-model="fullName1"><br>
    姓名:<input type="text" placeholder="顯示姓名" v-model="fullName2"><br>
    姓名:<input type="text" placeholder="顯示姓名" v-model="fullName3"><br>
  </fieldset>
</template>

<script lang="ts">
import {reactive, ref, computed, watch, watchEffect} from "vue";
export default {
  setup() {
    const user=reactive({
      firstName:'東方',
      lastName: '不敗'
    })
    /*
    * Vue3中的計算屬性
    * 計算屬性如果只傳入一個回調(diào)函數(shù),那么表示get
    * 返回的是一個ref對象
    * */
    const fullName1=computed(()=>{
      return user.firstName + '-' + user.lastName
    })
    const fullName2=computed({
      get(){
        return user.firstName + '-' + user.lastName
      },
      set(val){
        const name=val.split('-')
        user.firstName=name[0]
        user.lastName=name[1]
      }
    })
    // 監(jiān)視屬性
    let fullName3=ref('')
    watch(user,({firstName,lastName})=>{ // user里面對象解構(gòu)賦值
      fullName3.value=firstName + '-' +lastName
    },{immediate:true}) // immediate 開始時執(zhí)行一次 還可以加deep 深度監(jiān)視
    // watchEffect(()=>{
    //   fullName3.value=user.firstName + '-' +user.lastName
    // }) // 更智能,開始就自動執(zhí)行一次

    /*
    * wathc可以監(jiān)視多個屬性,監(jiān)聽非響應(yīng)式數(shù)據(jù)時,需要()=>
    * */
    watch([()=>user.firstName,()=>user.lastName],()=>{
      console.log("watch執(zhí)行了")
    })
    return {
      user,
      fullName1,
      fullName2,
      fullName3
    }
  }
}
</script>

到此這篇關(guān)于vue3響應(yīng)式數(shù)據(jù)與watch屬性的文章就介紹到這了,更多相關(guān)vue3 watch屬性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Element MessageBox彈框的具體使用

    Element MessageBox彈框的具體使用

    這篇文章主要介紹了Element MessageBox彈框的具體使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • vue?vue-touch移動端手勢詳解

    vue?vue-touch移動端手勢詳解

    這篇文章主要介紹了vue?vue-touch移動端手勢詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue項目 npm run build 打包項目防止瀏覽器緩存的操作方法

    vue項目 npm run build 打包項目防止瀏覽器緩存的操作方法

    這篇文章主要介紹了vue項目 npm run build 打包項目防止瀏覽器緩存的操作方法,本文給大家推薦兩種方法,每種方法通過實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • Vue?設(shè)置圖片不轉(zhuǎn)為base64的方式

    Vue?設(shè)置圖片不轉(zhuǎn)為base64的方式

    這篇文章主要介紹了Vue實現(xiàn)設(shè)置圖片不轉(zhuǎn)為base64的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • vue項目使用node連接數(shù)據(jù)庫的方法(前后端分離)

    vue項目使用node連接數(shù)據(jù)庫的方法(前后端分離)

    這篇文章主要介紹了vue項目使用node連接數(shù)據(jù)庫(前后端分離),本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12
  • Vue實現(xiàn)導(dǎo)入Excel功能步驟詳解

    Vue實現(xiàn)導(dǎo)入Excel功能步驟詳解

    這篇文章主要介紹了Vue實現(xiàn)導(dǎo)入Excel功能,本文分步驟給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-07-07
  • vue中使用Axios最佳實踐方式

    vue中使用Axios最佳實踐方式

    Axios?是一個基于?promise?的網(wǎng)絡(luò)請求庫,可以用于瀏覽器和?node.js,Axios?使用簡單,包尺寸小且提供了易于擴展的接口,這篇文章主要介紹了vue中使用Axios最佳實踐,需要的朋友可以參考下
    2022-09-09
  • 在vue中根據(jù)光標(biāo)的顯示與消失實現(xiàn)下拉列表

    在vue中根據(jù)光標(biāo)的顯示與消失實現(xiàn)下拉列表

    這篇文章主要介紹了在vue中根據(jù)光標(biāo)的顯示與消失實現(xiàn)下拉列表,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Vue2.x 的雙向綁定原理及實現(xiàn)

    Vue2.x 的雙向綁定原理及實現(xiàn)

    這篇文章主要介紹了Vue2.x 的雙向綁定原理,Vue 是利用的 Object.defineProperty() 方法進行的數(shù)據(jù)劫持,利用 set、get 來檢測數(shù)據(jù)的讀寫。需要的朋友可以參考下面文章的具體內(nèi)容
    2021-09-09
  • Vue element-ui父組件控制子組件的表單校驗操作

    Vue element-ui父組件控制子組件的表單校驗操作

    這篇文章主要介紹了Vue element-ui父組件控制子組件的表單校驗操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07

最新評論