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

Vue3 響應(yīng)式 API 及 reactive 和 ref 的用法示例詳解

 更新時間:2023年06月21日 11:42:26   作者:黛琳ghz  
響應(yīng)式是一種允許以聲明式的方式去適應(yīng)變化的編程范例,這篇文章主要介紹了關(guān)于Vue3響應(yīng)式API及reactive和ref的用法,需要的朋友可以參考下

??前言

這篇文章記錄一下 Vue3 響應(yīng)式的內(nèi)容,其中還包括了 reactiveref 的用法。響應(yīng)式是一種允許以聲明式的方式去適應(yīng)變化的編程范例,接下來我們一起看看。

??關(guān)于響應(yīng)式

Vue 框架的特點之一就是響應(yīng)式。Vue 2.x 是基于 Object.defineProperty() 方法實現(xiàn)響應(yīng)式。但是 Object.defineProperty() 方法有一定的局限性,例如 Object.defineProperty() 無法監(jiān)聽對象屬性的新增。為了克服解決這種缺陷,Vue3.x 版本引入 Proxy 對象來實現(xiàn)響應(yīng)式。

Proxy 不僅可以監(jiān)聽到屬性的變化和刪除,同時還支持代理復(fù)雜的數(shù)據(jù)結(jié)構(gòu),例如 Map 、Set 、Symbol 等等。但是 Proxy 也是缺點,就是不兼容 IE 11(實際開發(fā)中如果要求程序員兼容 IE ,他可能反手就紅溫了hhh)。言歸正傳,如果要考慮兼容 IE 11 的問題,可以使用 Vue 2.x 版本來開發(fā)。

??reactive 的用法

Vuereactive() 方法通過接收一個對象,返回對象的響應(yīng)式副本,我們可以看看下面這段代碼。

<template>
  <p>
    響應(yīng)式Count: {{ reactiveCount.count }}
    <button @click="reactiveCount.count++">++</button>
  </p>
</template>
<script setup lang="ts">
import { reactive } from "vue";
interface CountObject {
  count: number;
}
const reactiveCount = reactive<CountObject>({ count: 0 });
</script>

這里通過 reactive() 方法將 { count: 0 }對象封裝成一個響應(yīng)式對象,并且可以通過點擊頁面中的按鈕來動態(tài)實現(xiàn)數(shù)據(jù)更新,運行效果如下圖 (項目剛創(chuàng)建的,路有什么的沒配置,忽略無關(guān)內(nèi)容)。

reactive() 方法封裝對象成為響應(yīng)式并不僅僅是一層,而是深層轉(zhuǎn)換。如果想要在 script 模板中修改對象某個屬性的值,直接訪問進行修改即可。代碼如下。

<template>
  <p>學(xué)生: {{ student.name }}</p>
  <p>成績: {{ student.test_socre.name }} | {{ student.test_socre.score }}分</p>
  <button @click="rest">rest mark</button>
</template>
<script setup lang="ts">
import { reactive } from "vue";
interface Student {
  name: string;
  test_socre: {
    name: string;
    score: number;
  };
}
const student = reactive<Student>({
  name: "ghz",
  test_socre: {
    name: "C語言",
    score: 98,
  },
});
const rest = () => {
  student.test_socre.score = 0;
};
</script>

點擊按鈕后,分數(shù)重置。

這里 reactive() 將一個比較復(fù)雜的對象轉(zhuǎn)換成了響應(yīng)式對象,通過點擊按鈕,調(diào)用 rest 方法,將 student 對象中的 test_score 下的 score 重置為 0 分。同時,在方法內(nèi)部,可以直接訪問對象的屬性進行修改數(shù)值。

??ref 的用法

Vue 3.x 中,ref() 負責(zé)將基本數(shù)據(jù)類型的數(shù)據(jù)封裝成響應(yīng)式數(shù)據(jù)。在所使用的 TypeScript 中,基本數(shù)據(jù)類型有:String 、Number 、BooleanBigint 、SymbolUndefinedNull。

ref() 負責(zé)接受上述類型的數(shù)組返回一個響應(yīng)式而且可變的 ref 對象,如果要獲取其中的值,需要訪問對象的 .value 屬性來獲取。我們可以看看下面這段代碼。

<template>
  <div></div>
</template>
<script setup lang="ts">
import { ref } from "vue";
const str = ref<string>("hello");
const num = ref<number>(123);
const bool = ref<boolean>(true);
const bigint = ref<bigint>(9007199254740991n);
const symbolObject = Symbol("foo");
const symb = ref<symbol>(symbolObject);
const und = ref<undefined>(undefined);
const nul = ref<null>(null);
console.log(str.value); // hello
console.log(num.value); // 123
console.log(bool.value); // true
console.log(bigint.value); // 9007199254740991nX
console.log(typeof symb.value); // symbol
console.log(symb.value); // Symbol(foo)
console.log(und.value); // undefined
console.log(nul.value); // null
</script>

從上面的這段代碼中可以看到,如果想要在 script 模板中讀取或者修改 ref 對象的值,需要從 .value 屬性中獲得。在模板中可以直接通過插值表達式讀取出來。這里需要注意的是 ref 是響應(yīng)式對象,所以一旦 ref.value 屬性值被修改,那么對應(yīng)的頁面模板也會重新渲染。

reactive() 負責(zé)封裝對象變量,ref() 負責(zé)封裝基礎(chǔ)數(shù)據(jù)類型變量,這兩個方法是 Vue3 最常見也最重要的命令之一。

??最后

以上就是這篇文章的全部內(nèi)容了,通過這篇文章,我們可以簡單了解學(xué)習(xí) Vue3 響應(yīng)式的內(nèi)容,通過實際案例我們也學(xué)習(xí)了 reactiveref 的用法。

到此這篇關(guān)于關(guān)于 Vue3 響應(yīng)式 API 以及 reactive 和 ref 的用法的文章就介紹到這了,更多相關(guān)Vue3 reactive 和 ref 的用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue 加載遠程組件的解決方案

    Vue 加載遠程組件的解決方案

    最近的項目有一個加載遠程組件的需求,基于此我對 Vue 加載遠程組件的方案進行了研究,并且整理了兩個可行的解決方案,有感興趣的小伙伴跟著小編一起來看看吧
    2023-07-07
  • Vue3?全局切換字體大小的實現(xiàn)

    Vue3?全局切換字體大小的實現(xiàn)

    本文主要介紹了Vue3?全局切換字體大小的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-03-03
  • vue-element-admin配置小結(jié)

    vue-element-admin配置小結(jié)

    本文主要介紹了vue-element-admin配置小結(jié),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue如何實現(xiàn)簡易流程圖

    vue如何實現(xiàn)簡易流程圖

    這篇文章主要介紹了vue如何實現(xiàn)簡易流程圖問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 詳解vue-cli@2.x項目遷移日志

    詳解vue-cli@2.x項目遷移日志

    這篇文章主要介紹了詳解vue-cli@2.x項目遷移日志,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 詳解vue組件之間的通信

    詳解vue組件之間的通信

    這篇文章主要介紹了vue組件之間的通信,幫助大家更好的理解和學(xué)習(xí)前端的相關(guān)知識,感興趣的朋友可以了解下
    2020-08-08
  • vue如何通過日期篩選數(shù)據(jù)

    vue如何通過日期篩選數(shù)據(jù)

    這篇文章主要介紹了vue如何通過日期篩選數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue-form表單驗證是否為空值的實例詳解

    vue-form表單驗證是否為空值的實例詳解

    今天小編就為大家分享一篇vue-form表單驗證是否為空值的實例詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • vue如何在vue.config.js文件中導(dǎo)入模塊

    vue如何在vue.config.js文件中導(dǎo)入模塊

    這篇文章主要介紹了vue如何在vue.config.js文件中導(dǎo)入模塊問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • Vue代理報錯404問題及解決(vue配置proxy)

    Vue代理報錯404問題及解決(vue配置proxy)

    這篇文章主要介紹了Vue代理報錯404問題及解決(vue配置proxy),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12

最新評論