91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue-next函數式api的示例分析

發布時間:2021-08-03 09:33:31 來源:億速云 閱讀:104 作者:小新 欄目:web開發

小編給大家分享一下vue-next函數式api的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

setup

setup 會作為編寫組件業務邏輯的主戰場,各種 hook 類型的方法均需要在 setup 這個作用域下調用,直接來看 RFC 中的例子:

<template>
 <button @click="increment">
  Count is: {{ state.count }}, double is: {{ state.double }}
 </button>
</template>

<script>
import { reactive, computed } from 'vue'

export default {
 setup() {
  const state = reactive({
   count: 0,
   double: computed(() => state.count \* 2)
  })

  function increment() {
   state.count++
  }

  return {
   state,
   increment
  }
 }
}
</script>

其代碼結構看起來和 vue2 基本保持一致,不過有以下幾點需要注意:

  • setup 本身的調用時機,從目前的源碼來看,介于 beforeCreate 和 created 這兩個生命周期之間,言外之意,就是你無法在這里使用 this 指向當前組件實例

  • 對于 state 的聲明,我們使用 reactive 這個 api 來構造,對于 computed state 的聲明,使用 computed,兩者本質上均是 Proxy 對象

  • 對于組件方法的聲明,我們直接通過聲明普通函數的方式進行聲明即可,對于 state 的變更,直接通過閉包使用 reactive 返回的 Proxy 對象即可

  • setup 的返回值被稱作 render context,顧名思義,就是模板中可以訪問到的各種數據和方法的上下文對象,我在之前的文章中曾提及,模板在解析數據時,會優先考慮從 data 對象取值,之后就是這個 render context 了

  • 除了返回 render context,還可以返回模板渲染函數,對,就是那個 h(...),這種形式對應的情況是,當我們沒有聲明 template 屬性時

在 vue-next 中,我們直接從 vue 導入 reactive 、computed 以及其他的 api 即可,如果在 vue2 版本上,我們還可以通過使用 composition-api 這個 plugin 來使用這些 api。

state

聲明 state 主要有以下幾種形式。

基礎類型

基礎類型可以通過 ref 這個 api 來聲明,如下:

import { ref } from "vue";

export default {
setup() {
 const count = ref(0);
 
 function inc() {
  count.value++;
 }
 
 return { count, inc };
}
};

之所以要通過 ref,是因為 js 中的基礎類型傳值不是引用傳值,因此 vue-next 內部會自動將它封裝為一個 ref 對象,其值指向原始值。當然,ref 指向引用類型也是沒有問題的,其 value 指向引用類型變量的引用。

引用類型

引用類型除了可以使用 ref 來聲明,也可以直接使用 reactive,如下:

import { reactive } from "vue";

export default {
 setup() {
  const state = reactive({
    count: 0
  });
  
  function inc() {
   state.count++;
  }
  
  return { state, inc };
  // 或者通過 toRefs 方法
  // return { ...toRefs(state), inc };
 }
};

這里使用 toRefs 的原因主要是因為,如果是 reactive 產生的對象,由于我們要只是保存對于該 Proxy 對象的引用,我們無法使用解構來將它 flat,而 toRefs 會將每一個屬性在內部包裹為一個 ref 對象。

props

對于 prop 可以通過如下代碼聲明及使用:

export default {
 props: {
  count: Number
 },
 setup(props) {
  watch(() => {
   console.log(\`count is: \` + props.count)
  })
 }
}

這里可以發現其實和 vue2 中聲明的方式基本一樣,但值得注意的是,在 vue-next 中,props 的類型聲明不是必須的,如果你使用 typescript,完全可以改寫為如下的版本:

interface PropTypesI {
  count: number
}

export default {
 setup(props: PropTypesI) {
  watch(() => {
   console.log(\`count is: \` + props.count)
  })
 }
}

除此之外,還可以直接通過 watch 方法來觀察某個 prop 的變動,這是為什么呢?答案非常簡單,就是 props 本身在源碼中,也是一個被 reactive 包裹后的對象,因此它具有響應性,所以在 watch 方法中的回調函數會自動收集依賴,之后當 count 變動時,會自動調用這些回調邏輯。

context

在 setup 那一小節中,我們知道,setup 在調用時,組件實例還未創建,那意味著我們無法使用 this 訪問當前實例,那我想通過 this 在 vue2 中訪問一些內置屬性,怎么辦?比如 attrs 或者 emit。我們可以通過 setup 的第二個參數:

setup(props, context) {
 do anything...
}

這個 context 對象也是一個 Proxy 對象,當我們通過 context.attrs 訪問其屬性時,本質上代理對象會將訪問指向組件的內部實例(即之間文章中提及的 componentInternalInstance)。

生命周期

每一個 vue2 中的組件生命周期函數,當前都對應一個生命周期 hook,比如:

import { onMounted, onUpdated, onUnmounted } from "vue";

setup() {
 onMounted(() => { ... });
 onUpdated(() => { ... });
 onUnmounted(() => { ... });
}

這里值得注意的一點在于,對于 beforeCreate 和 created 生命周期,雖然有響應的 hook,但是我覺的沒有必要單獨使用了,因為這些邏輯代碼大部分是一些初始化邏輯的代碼,直接寫在 setup 方法中即可。

如何復用代碼

在這個基礎上,復用代碼的方式也不再像 vue2 中的那樣,通過 mixin 或者 HOC 來達到復用代碼的目的,這里稍微說一下,這些復用代碼方式中比較顯著的缺點有:

  • 隱藏了數據來源,主要體現在 mixin 中

  • 會犧牲一些性能,主要體現在 HOC 中

  • 可能會遇到命名沖突問題,主要體現在 mixin 中

在 vue-next 中,復用代碼的邏輯本質上是利用這些 hook 來拆分業務邏輯與狀態,如果你比較熟悉 react hooks 的話,應該很快就能明白我指的是什么意思。如果我們將邏輯都寫在 setup 方法中,很快代碼就會變得難以維護,在這方面,我們可以將一些耦合在一起的代碼抽離出來,同時以 use 前綴命名,聲明一個自定義的 hook,如下:

export default {
 setup() {
  const data = useSearch()
  const { sortedData, sort } = useSorting(data)
  return { data, sortedData, sort }
 }
}

function useSearch() { 
  ...fetch data
}

function useSort(data) { 
  ...sort data
}

除了以 inline 的方式來聲明,還可以將這些自定義的 hook 聲明在單獨的文件中,直接通過 import 導入即可,比如:

import useSearch from '@hooks/search'
import useSort from '@hooks/sort'

與 react hooks 對比

vue-next 在這方面借鑒了 react hooks 的設計思想,但是從實現層來講,它們是不一樣的,主要有以下幾點:

  • vue-next 不依賴于其調用順序,而 react 依賴

  • vue-next 提供了生命周期方法,而 react 刻意模糊生命周期的概念

  • vue-next 基于響應式系統實現,意味它的依賴不需要顯示聲明(而且是自動的),而 react 需要手動聲明依賴數組

以上是“vue-next函數式api的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

克东县| 西和县| 寿宁县| 江津市| 和田县| 佛山市| 呼伦贝尔市| 伊金霍洛旗| 上饶县| 丰县| 宝应县| 襄垣县| 商洛市| 铅山县| 定结县| 衡水市| 麻城市| 西林县| 萨嘎县| 元朗区| 柯坪县| 德昌县| 盈江县| 遵义市| 东至县| 温泉县| 城口县| 馆陶县| 邻水| 犍为县| 郯城县| 江陵县| 通州市| 竹北市| 古田县| 邯郸市| 寻乌县| 历史| 进贤县| 秦安县| 延吉市|