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

vue數(shù)據(jù)監(jiān)聽(tīng)解析Object.defineProperty與Proxy區(qū)別

 更新時(shí)間:2023年03月13日 09:13:54   作者:可畏  
這篇文章主要為大家介紹了vue數(shù)據(jù)監(jiān)聽(tīng)解析Object.defineProperty Proxy源碼示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

前言

總能深深感覺(jué)到自己能力有限,寫(xiě)這篇文章的目的純粹是因?yàn)榘l(fā)現(xiàn)在實(shí)際工作中,和一些小伙伴交流時(shí)發(fā)現(xiàn),雖然有些小伙伴大概知道 vue2vue3 的區(qū)別,但并沒(méi)有去進(jìn)一步思考一些深一點(diǎn)的東西。盡管能力有限,但想著自己在起步時(shí)候的艱難,就想著分享一下自己的一些看法,雖然不一定有多深入,但能引起大家的一些思考也是好的。

Object.defineProperty 與 Proxy 的區(qū)別

其實(shí)在 api 的命名上就能看出端倪,Object.defineProperty 顧名思義,是與對(duì)象和屬性有關(guān)的。 vue2 就是利用 definePropertysetget 方法去監(jiān)聽(tīng)對(duì)象屬性變化的。 而 Proxy 是直接去監(jiān)聽(tīng)一個(gè)對(duì)象的。

注意:他們?cè)谶@里的區(qū)別就是 Object.defineProperty 監(jiān)聽(tīng)的是對(duì)象的屬性,而 Proxy 監(jiān)聽(tīng)的是這個(gè)對(duì)象本身

在使用上的差異

如上所述,Object.defineProperty 監(jiān)聽(tīng)的是對(duì)象的屬性, 但是監(jiān)聽(tīng)屬性只能遍歷監(jiān)聽(tīng)對(duì)象已有的屬性,對(duì)于可能新增的屬性,vue2 是沒(méi)有辦法監(jiān)聽(tīng)的,頁(yè)面自然也就不會(huì)更新。 所以為了解決這個(gè)問(wèn)題 vue2 提供了 set 方法,當(dāng)新增屬性時(shí),可以通過(guò) set 方法為新增的屬性添加監(jiān)聽(tīng)器。
Proxy 帶來(lái)的問(wèn)題就是由于監(jiān)聽(tīng)的是一個(gè)對(duì)象,自然能監(jiān)聽(tīng)對(duì)象的所有屬性變化,那么也就不再需要 set 這個(gè)方法了。

但是由于監(jiān)聽(tīng)的是對(duì)象,所以沒(méi)法處理基礎(chǔ)類(lèi)型。當(dāng)我們使用 ref(false) 去創(chuàng)建一個(gè)基本類(lèi)型的響應(yīng)式變量時(shí),本質(zhì)相當(dāng)于 reactive({value: false})。于是 Vue3 有了一個(gè)很奇怪的現(xiàn)象, 明明想用 ref 方法監(jiān)聽(tīng)一個(gè)基礎(chǔ)類(lèi)型,卻需要通過(guò) .value 才能獲取到具體值。

總結(jié)與思考

總的來(lái)說(shuō),Proxy 雖然解決了 set 的坑,但是又埋下了 ref 的坑,那么 Proxy 值得使用嗎?

我的理解是值得的。原因就是同樣監(jiān)聽(tīng)一個(gè)對(duì)象,之前要為每個(gè)屬性設(shè)置監(jiān)聽(tīng)器,現(xiàn)在不需要了,性能和屬性管理成本都能直線下降。

以上就是 vue數(shù)據(jù)監(jiān)聽(tīng)解析Object.defineProperty與Proxy區(qū)別的詳細(xì)內(nèi)容,更多關(guān)于 vue數(shù)據(jù)監(jiān)聽(tīng)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue數(shù)據(jù)驅(qū)動(dòng)模擬實(shí)現(xiàn)2

    Vue數(shù)據(jù)驅(qū)動(dòng)模擬實(shí)現(xiàn)2

    這篇文章主要介紹了Vue數(shù)據(jù)驅(qū)動(dòng)模擬實(shí)現(xiàn)的相關(guān)資料,實(shí)現(xiàn)Observer構(gòu)造函數(shù),監(jiān)聽(tīng)已有數(shù)據(jù)data中的所有屬性,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • vue2實(shí)現(xiàn)封裝動(dòng)態(tài)表單組件

    vue2實(shí)現(xiàn)封裝動(dòng)態(tài)表單組件

    這篇文章主要介紹了vue2實(shí)現(xiàn)封裝動(dòng)態(tài)表單組件,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • vue路由權(quán)限和按鈕權(quán)限的實(shí)現(xiàn)示例

    vue路由權(quán)限和按鈕權(quán)限的實(shí)現(xiàn)示例

    本文主要介紹了vue路由權(quán)限和按鈕權(quán)限的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • vue初嘗試--項(xiàng)目結(jié)構(gòu)(推薦)

    vue初嘗試--項(xiàng)目結(jié)構(gòu)(推薦)

    這篇文章主要介紹了vue初嘗試--項(xiàng)目結(jié)構(gòu)的相關(guān)知識(shí),需要的朋友可以參考下
    2018-01-01
  • Vuejs中使用markdown服務(wù)器端渲染的示例

    Vuejs中使用markdown服務(wù)器端渲染的示例

    這篇文章主要介紹了Vuejs 中使用 markdown的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-11-11
  • vue + vuex todolist的實(shí)現(xiàn)示例代碼

    vue + vuex todolist的實(shí)現(xiàn)示例代碼

    這篇文章主要介紹了vue + vuex todolist的實(shí)現(xiàn)示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • vue中循環(huán)多個(gè)li(表格)并獲取對(duì)應(yīng)的ref的操作代碼

    vue中循環(huán)多個(gè)li(表格)并獲取對(duì)應(yīng)的ref的操作代碼

    我想要獲取每一個(gè)循環(huán)并獲取每一個(gè)li(或者其它循環(huán)項(xiàng))的ref,以便于后續(xù)的操作,接下來(lái)通過(guò)本文給大家分享vue中循環(huán)多個(gè)li(表格)并獲取對(duì)應(yīng)的ref的操作代碼,感興趣的朋友跟隨小編一起看看吧
    2024-02-02
  • vue生命周期四個(gè)階段created和mount詳解

    vue生命周期四個(gè)階段created和mount詳解

    這篇文章主要介紹了vue生命周期四個(gè)階段created和mount,本文給大家介紹的非常詳細(xì),補(bǔ)充介紹了什么是實(shí)例,什么是實(shí)例被掛載到DOM,什么是dom,dao操作又是什么,感興趣的朋友跟隨小編一起看看吧
    2024-02-02
  • Electron + vue 打包桌面操作流程詳解

    Electron + vue 打包桌面操作流程詳解

    這篇文章主要介紹了Electron + vue 打包桌面操作流程,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-06-06
  • Vue使用視頻作為網(wǎng)頁(yè)背景的實(shí)現(xiàn)指南

    Vue使用視頻作為網(wǎng)頁(yè)背景的實(shí)現(xiàn)指南

    在現(xiàn)代網(wǎng)頁(yè)設(shè)計(jì)中,視頻背景逐漸成為一種流行的設(shè)計(jì)趨勢(shì),它不僅能夠提升網(wǎng)頁(yè)的動(dòng)態(tài)效果,還可以在視覺(jué)上抓住用戶的注意力,本文將詳細(xì)講解如何在頁(yè)面中使用視頻作為背景,并確保內(nèi)容可見(jiàn)、頁(yè)面元素布局合理,需要的朋友可以參考下
    2024-10-10

最新評(píng)論