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

Vue 3.0 前瞻Vue Function API新特性體驗

 更新時間:2019年08月12日 11:06:44   作者:counterxing  
這篇文章主要介紹了Vue 3.0 前瞻Vue Function API新特性體驗,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

最近 Vue 官方公布了 Vue 3.0 最重要的RFC:Function-based component API,并發(fā)布了兼容 Vue 2.0 版本的 plugin:vue-function-api,可用于提前體驗 Vue 3.0 版本的 Function-based component API。筆者出于學習的目的,提前在項目中嘗試了vue-function-api。

筆者計劃寫兩篇文章,本文為筆者計劃的第一篇,主要為筆者在體驗 Vue Function API 的學習心得。第二篇計劃寫閱讀vue-function-api的核心部分代碼原理,包括setup、observable、lifecycle。

本文閱讀時間約為15~20分鐘。

概述

Vue 2.x 及以前的高階組件的組織形式或多或少都會面臨一些問題,特別是在需要處理重復邏輯的項目中,一旦開發(fā)者組織項目結構組織得不好,組件代碼極有可能被人詬病為“膠水代碼”。而在 Vue 2.x 及之前的版本,解決此類問題的辦法大致是下面的方案:

筆者維護的項目也需要處理大量復用邏輯,在這之前,筆者一直嘗試使用mixin的方式來實現組件的復用。有些問題也一直會對開發(fā)者和維護者造成困惑,如一個組件同時mixin多個組件,很難分清對應的屬性或方法寫在哪個mixin里。其次,mixin的命名空間沖突也可能造成問題。難以保證不同的mixin不用到同一個屬性名。為此,官方團隊提出函數式寫法的意見征求稿,也就是RFC:Function-based component API。使用函數式的寫法,可以做到更靈活地復用組件,開發(fā)者在組織高階組件時,不必在組件組織上考慮復用,可以更好地把精力集中在功能本身的開發(fā)上。

注:本文只是筆者使用vue-function-api提前體驗 Vue Function API ,而這個 API 只是 Vue 3.0 的 RFC,而并非與最終 Vue 3.x API 一致。發(fā)布后可能有不一致的地方。

在 Vue 2.x 中使用

要想提前在Vue 2.x中體驗 Vue Function API ,需要引入vue-function-api,基本引入方式如下:

import Vue from 'vue';
import { plugin as VueFunctionApiPlugin } from 'vue-function-api';

Vue.use(VueFunctionApiPlugin);

基本組件示例

先來看一個基本的例子:

<template>
  <div>
    <span>count is {{ count }}</span>
    <span>plusOne is {{ plusOne }}</span>
    <button @click="increment">count++</button>
  </div>
</template>

<script>
import Vue from 'vue';
import { value, computed, watch, onMounted } from 'vue-function-api';

export default {
  setup(props, context) {
    // reactive state
    const count = value(0);
    // computed state
    const plusOne = computed(() => count.value + 1);
    // method
    const increment = () => {
      count.value++;
    };
    // watch
    watch(
      () => count.value * 2,
      val => {
        console.log(`count * 2 is ${val}`);
      }
    );
    // lifecycle
    onMounted(() => {
      console.log(`mounted`);
    });
    // expose bindings on render context
    return {
      count,
      plusOne,
      increment,
    };
  },
};
</script>

詳解

setup

setup函數是Vue Function API 構建的函數式寫法的主邏輯,當組件被創(chuàng)建時,就會被調用,函數接受兩個參數,分別是父級組件傳入的props和當前組件的上下文context??聪旅孢@個例子,可以知道在context中可以獲取到下列屬性值:

const MyComponent = {
  props: {
    name: String
  },
  setup(props, context) {
    console.log(props.name);
    // context.attrs
    // context.slots
    // context.refs
    // context.emit
    // context.parent
    // context.root
  }
}

value & state

value函數創(chuàng)建一個包裝對象,它包含一個響應式屬性value:

那么為何要使用value呢,因為在JavaScript中,基本類型并沒有引用,為了保證屬性是響應式的,只能借助包裝對象來實現,這樣做的好處是組件狀態(tài)會以引用的方式保存下來,從而可以被在setup中調用的不同的模塊的函數以參數的形式傳遞,既能復用邏輯,又能方便地實現響應式。

直接獲取包裝對象的值必須使用.value,但是,如果包裝對象作為另一個響應式對象的屬性,Vue內部會通過proxy來自動展開包裝對象。同時,在模板渲染的上下文中,也會被自動展開。

import { state, value } from 'vue-function-api';
const MyComponent = {
  setup() {
    const count = value(0);
    const obj = state({
      count,
    });
    console.log(obj.count) // 作為另一個響應式對象的屬性,會被自動展開

    obj.count++ // 作為另一個響應式對象的屬性,會被自動展開
    count.value++ // 直接獲取響應式對象,必須使用.value

    return {
      count,
    };
  },
  template: `<button @click="count++">{{ count }}</button>`,
};

如果某一個狀態(tài)不需要在不同函數中被響應式修改,可以通過state創(chuàng)建響應式對象,這個state創(chuàng)建的響應式對象并不是包裝對象,不需要使用.value來取值。

watch & computed

watch和computed的基本概念與 Vue 2.x 的watch和computed一致,watch可以用于追蹤狀態(tài)變化來執(zhí)行一些后續(xù)操作,computed用于計算屬性,用于依賴屬性發(fā)生變化進行重新計算。

computed返回一個只讀的包裝對象,和普通包裝對象一樣可以被setup函數返回,這樣就可以在模板上下文中使用computed屬性??梢越邮軆蓚€參數,第一個參數返回當前的計算屬性值,當傳遞第二個參數時,computed是可寫的。

import { value, computed } from 'vue-function-api';

const count = value(0);
const countPlusOne = computed(() => count.value + 1);

console.log(countPlusOne.value); // 1

count.value++;
console.log(countPlusOne.value); // 2

// 可寫的計算屬性值
const writableComputed = computed(
  // read
  () => count.value + 1,
  // write
  val => {
    count.value = val - 1;
  },
);

watch第一個參數和computed類似,返回被監(jiān)聽的包裝對象屬性值,不過另外需要傳遞兩個參數:第二個參數是回調函數,當數據源發(fā)生變化時觸發(fā)回調函數,第三個參數是options。其默認行為與 Vue 2.x 有所不同:

  • lazy:是否會在組件創(chuàng)建時就調用一次回調函數,與 Vue 2.x 相反,lazy默認是false,默認會在組件創(chuàng)建時調用一次。
  • deep:與 Vue 2.x 的 deep 一致
  • flush:有三個可選值,分別為 'post'(在渲染后,即nextTick后才調用回調函數),'pre'(在渲染前,即nextTick前調用回調函數),'sync'(同步觸發(fā))。默認值為'post'。
// double 是一個計算包裝對象
const double = computed(() => count.value * 2);

watch(double, value => {
  console.log('double the count is: ', value);
}); // -> double the count is: 0

count.value++; // -> double the count is: 2

當watch多個被包裝對象屬性時,參數均可以通過數組的方式進行傳遞,同時,與 Vue 2.x 的vm.$watch一樣,watch返回取消監(jiān)聽的函數:

const stop = watch(
  [valueA, () => valueB.value],
  ([a, b], [prevA, prevB]) => {
    console.log(`a is: ${a}`);
    console.log(`b is: $`);
  }
);
stop();

注意:在RFC:Function-based component API初稿中,有提到effect-cleanup,是用于清理一些特殊情況的副作用的,目前已經在提案中被取消了。

生命周期

所有現有的生命周期都有對應的鉤子函數,通過onXXX的形式創(chuàng)建,但有一點不同的是,destoryed鉤子函數需要使用unmounted代替:

import { onMounted, onUpdated, onUnmounted } from 'vue-function-api';

const MyComponent = {
  setup() {
    onMounted(() => {
      console.log('mounted!');
    });
    onUpdated(() => {
      console.log('updated!');
    });
    // destroyed 調整為 unmounted
    onUnmounted(() => {
      console.log('unmounted!');
    });
  },
};

一些思考

上面的詳解部分,主要抽取的是 Vue Function API 的常見部分,并非RFC:Function-based component API的全部,例如其中的依賴注入,TypeScript類型推導等優(yōu)勢,在這里,由于篇幅有限,想要了解更多的朋友,可以點開RFC:Function-based component API查看。個人也在Function-based component API討論區(qū)看到了更多地一些意見:

  • 由于底層設計,在setup取不到組件實例this的問題,這個問題在筆者嘗試體驗時也遇到了,期待正式發(fā)布的 Vue 3.x 能夠改進這個問題。
  • 對于基本類型的值必須使用包裝對象的問題:在 RFC 討論區(qū),為了同時保證TypeScript類型推導、復用性和保留Vue的數據監(jiān)聽,包裝屬性必須使用.value來取值是討論最激烈的
  • 關于包裝對象value和state方法命名不清晰可能導致開發(fā)者誤導等問題,已經在Amendment proposal to Function-based Component API這個提議中展開了討論:
setup() {
  const state = reactive({
    count: 0,
  });

  const double = computed(() => state.count * 2);

  function increment() {
    state.count++;
  }

  return {
    ...toBindings(state), // retains reactivity on mutations made to `state`
    double,
    increment,
  };
}

  • 引入reactive API 和 binding API,其中reactive API 類似于 state API , binding API 類似于 value API。
  • 之前使用的方法名state在 Vue 2.x 中可能被用作組件狀態(tài)對象,導致變量命名空間的沖突問題,團隊認為將state API 更名為 reactive 更為優(yōu)雅。開發(fā)者能夠寫出const state = ... ,然后通過state.xxxx這種方式來獲取組件狀態(tài),這樣也相對而言自然一些。
  • value方法用于封裝基本類型時,確實會出現不夠優(yōu)雅的.value的情況,開發(fā)者可能會在直接對包裝對象取值時忘記使用.value,修正方案提出的 reactive API,其含義是創(chuàng)建響應式對象,初始化狀態(tài)state就使用reactive創(chuàng)建,可保留每項屬性的getter和setter,這么做既滿足類型推導,也可以保留響應式引用,從而可在不同模塊中共享狀態(tài)值的引用。
  • 但reactive可能導致下面的問題,需要引入binding API。 解決,如使用reactive創(chuàng)建的響應式對象,對其使用拓展運算符...時,則會丟失對象的getter和setter,提供toBindings方法能夠保留狀態(tài)的響應式。

下一篇文章中,筆者將閱讀vue-function-api的核心部分代碼原理,包括setup、observable、lifecycle等,從內部探索 Vue Function API 可能帶給我們的改變。

當然,目前 Vue Function API 還處在討論階段,Vue 3.0 還處在開發(fā)階段,還是期待下半年 Vue 3.0 的初版問世吧,希望能給我們帶來更多的驚喜。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Vue.js 利用v-for中的index值實現隔行變色

    Vue.js 利用v-for中的index值實現隔行變色

    這篇文章主要介紹了Vue.js 利用v-for中的index值實現隔行變色效果,首先定義好樣式,利用v-for中的index值,然后綁定樣式來實現隔行變色,需要的朋友可以參考下
    2018-08-08
  • 使用wang-editor上傳圖片后端接收不到的問題解決

    使用wang-editor上傳圖片后端接收不到的問題解決

    這篇文章主要介紹了如何解決wang-editor 上傳圖片后端接收不到的問題,文中通過圖文結合給大家講解的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下
    2024-02-02
  • 使用ElementUI寫一個前端分頁查詢的實例

    使用ElementUI寫一個前端分頁查詢的實例

    本文主要介紹了使用ElementUI寫一個前端分頁查詢的實例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • 結合Vue控制字符和字節(jié)的顯示個數的示例

    結合Vue控制字符和字節(jié)的顯示個數的示例

    這篇文章主要介紹了結合Vue控制字符和字節(jié)的顯示個數的示例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • vue實現某元素吸頂或固定位置顯示(監(jiān)聽滾動事件)

    vue實現某元素吸頂或固定位置顯示(監(jiān)聽滾動事件)

    這篇文章主要為大家詳細介紹了vue實現某元素吸頂或固定位置顯示,監(jiān)聽滾動事件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • Vue.js 應用性能優(yōu)化分析+解決方案

    Vue.js 應用性能優(yōu)化分析+解決方案

    這篇文章主要介紹了Vue.js 應用性能優(yōu)化分析以及解決方案,VueJS 是開發(fā)網站最受歡迎、最穩(wěn)定的 JavaScript 框架,但與其他框架一樣,如果您忽略它,性能就會受到影響,下面我們就一起來看看怎么才能讓性能提升吧
    2021-12-12
  • 淺談ElementUI中switch回調函數change的參數問題

    淺談ElementUI中switch回調函數change的參數問題

    今天小編就為大家分享一篇淺談ElementUI中switch回調函數change的參數問題,具有很好的價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Vue中的.vue文件的使用方式

    Vue中的.vue文件的使用方式

    這篇文章主要介紹了Vue中的.vue文件的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue ajax 攔截原理與實現方法示例

    vue ajax 攔截原理與實現方法示例

    這篇文章主要介紹了vue ajax 攔截原理與實現方法,結合實例形式分析了vue.js基于ajax攔截實現無刷新登錄的相關原理與操作技巧,需要的朋友可以參考下
    2019-11-11
  • VUEJS 2.0 子組件訪問/調用父組件的實例

    VUEJS 2.0 子組件訪問/調用父組件的實例

    下面小編就為大家分享一篇VUEJS 2.0 子組件訪問/調用父組件的實例。具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02

最新評論