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

Vue.js響應式數據的簡單實現方法(一看就會)

 更新時間:2022年03月01日 10:26:58   作者:將煥  
Vue最巧妙的特性之一是其響應式系統(tǒng),下面這篇文章主要給大家介紹了關于Vue.js響應式數據的簡單實現方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

引言

在Vue.js之中,Vue會自動跟蹤JavaScript狀態(tài)變化并在狀態(tài)發(fā)生改變時響應式地更新DOM,這就是Vue.js的兩大核心功能之一——響應性,是每一個Vue.js框架使用者必須熟練掌握的的功能。而得益于Vue.js自身支持的聲明式渲染,Vue.js的學習成本大大降低,就算是一個前端領域的小白,只要能看懂并簡單使用基本的HTML、JavaScript以及CSS,就能夠很快上手Vue.js。學,確實好學;用,真的好用!但,你對Vue.js框架的內部實現原理掌握多少呢?今天,就讓我們一起來簡單復現一下Vue.js數據響應式。

基本概念

副作用函數

什么是副作用函數?意如其名,副作用函數指的就是會產生副作用的函數。什么是副作用呢?就是會對函數作用域外的其他部分產生影響。俗話說:是藥三分毒,能治病,亦能致病。藥,就有副作用,副作用函數也是。

副作用函數代碼示例如下:

當effect函數執(zhí)行時,它會設置body的文本內容,從而直接或間接影響到其他任何對body文本內容有所依賴的函數的執(zhí)行。這就是一個簡單的副作用函數。

響應式數據

以我的理解,相較“響應式數據”而言更直白的叫法應該是“副作用數據”,就好像副作用函數的執(zhí)行可能會影響到函數作用域外的其他內容一樣,“副作用數據”的更改可能會直接或間接影響到所有依賴該數據的函數。

假響應式數據代碼示例如下:

如上圖,假設每一次修改對象obj的text屬性值,都會觸發(fā)函數effect的重新執(zhí)行,那么就可以說對象obj是一個響應式數據。當然,在這個示例里,實際上并沒有實現對obj對象的數據響應。

響應式數據的基本實現

實現思路

仔細觀察思考上述的例子,你可能會發(fā)現響應式數據的實現存在兩個關鍵點:

  • 副作用函數effect的執(zhí)行會觸發(fā)字段obj.text的讀取操作
  • 響應式數據obj.text值的修改會觸發(fā)字段obj.text的設置操作

事情的脈絡漸漸清晰起來:如果我們能夠攔截對象obj的讀取和設置操作,在副作用函數effect首次讀取字段obj.text的值時將它與對象obj關聯(lián)起來,此后每次重新設置字段obj.text的值,都會重新調用一次effect函數,這樣不就簡單的實現了對obj對象的響應嗎?

初步實現嘗試

實現的思路有了,那現在最關鍵的問題就是:如何實現攔截一個對象屬性的讀取和設置操作。如果你對JavaScript足夠熟悉,你可能就會想到Object.defineProperty函數以及Proxy對象代理。是的,這兩種方案都可以實現攔截一個對象屬性的讀取以及設置操作。事實上,用Object.defineProperty函數實現數據響應正是Vue.js 2中所采用的方法,而Proxy對象代理則正是Vue.js 3中所采用的方法。

接下來讓我們順著上面的思路采用proxy實現一下:

這就是采用Proxy代理對象簡單實現的數據響應式,你完全可以自行創(chuàng)建一個副作用函數effect進行測試。當然,考慮到復雜多變的環(huán)境,此時的數據相應式還有很多繼續(xù)完善的地方,讓我們再加加班,盡可能地給出一個相對完美的響應式數據實現方案。

完善響應系統(tǒng)

泛化副作用函數名

假如有一天,副作用的函數名不叫effect了。而是叫effect1或者effect2,甚至副作用函數沒有直白的名字了,變成了一個匿名函數,那么上述的響應系統(tǒng)方案顯然是行不通的。此時,為了滿足需求,我們需要提供一個用來注冊副作用函數的機制,達到泛化副作用函數名的效果。

注冊副作用函數名的代碼示例如下:

這樣,即使是一個匿名函數,也能夠被成功地注冊為副作用函數,注冊方法如下:

當然,此時攔截數據的讀取操作也需要做細微的調整:

修復漏洞

在很多時候,debug都是最頭疼的,特別是明明知道有bug,但就是找不到修復的方案,那種感覺真的像在坐牢……

現在我們來考慮一個極端條件:假如,在響應式數據對象obj上添加了一個原本不存在的屬性,那么會發(fā)生什么?如果你對前面的內容還不熟悉,可以再返回去翻翻代碼。你會發(fā)現一個驚人的事實:在響應式數據對象obj上添加一個原本不存在的屬性,會在這個新添加的屬性與相關的副作用函數之間建立響應聯(lián)系。冷靜下來思考一下,其實,導致該問題出現的根本原因是,沒有在副作用函數與被操作的目標字段之間建立明確的聯(lián)系。那,該如何解決呢?

你想想,在數據結構中存不存在一種結構,它具有一一對應的關系?有,當然有,映射就是。順著這個思路,那我們可不可以用映射的來建立目標字段與副作用函數key-value對應的關系?當然可以!那么我們就可以先把負責儲存函數的變量bucket聲明為一個映射Map<target, Map<key, Set()>>用來儲存響應式數據(key)-該響應式數據所有屬性相關的副作用函數(value),其中,Map<key, Set>儲存的就是響應式對象屬性與相應的副作用函數集,這樣,一個明確的聯(lián)系就建立起來了。而在著手優(yōu)化響應代碼之前,我們再想一想:bucket用WeakMap會不會比用Map要更好一點?我實話直說吧,當然應該用WeakMap,因為WeakMap的key是弱引用,不會影響到垃圾回收器的工作,會在合適的時候被回收,用在這里更合適。

具體實現代碼如下:

總結

總的來說,要想實現一個響應式數據其實就是利用Proxy對象代理或者Object.defineProperty對象來攔截對數據的讀取和設置操作并與相應的副作用函數作精確綁定。那么,如果現在要求你用Object.defineProperty對象來實現數據響應,你能夠獨立實現了嗎?試一下唄!

到此這篇關于Vue.js響應式數據的簡單實現方法的文章就介紹到這了,更多相關Vue.js響應式數據的實現內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 關于Vue中echarts響應式頁面變化resize()的用法介紹

    關于Vue中echarts響應式頁面變化resize()的用法介紹

    Vue項目中開發(fā)數據大屏,使用echarts圖表根據不同尺寸的屏幕進行適配,resize()可以調用echarts中內置的resize函數進行自適應縮放,本文將給大家詳細介紹resize()的用法,需要的朋友可以參考下
    2023-06-06
  • Vue 3中toRaw和markRaw的使用教程

    Vue 3中toRaw和markRaw的使用教程

    toRaw和markRaw是Vue 3中引入的新API,用于更精細地控制對象的代理和響應性,它們提供了在需要時繞過代理或禁用響應性的能力,有助于提高性能和更好地與第三方庫進行集成,本文給大家介紹Vue 3中toRaw和markRaw的使用,感興趣的朋友一起看看吧
    2023-10-10
  • 基于vue cli重構多頁面腳手架過程詳解

    基于vue cli重構多頁面腳手架過程詳解

    本文分步驟給大家介紹了基于vue cli重構多頁面腳手架過程,非常不錯,具有參考借鑒價值,需要的朋友參考下
    2018-01-01
  • Vue項目自動轉換 px 為 rem的實現方法

    Vue項目自動轉換 px 為 rem的實現方法

    這篇文章主要介紹了Vue項目自動轉換 px 為 rem的實現方法,本文是通過一系列的配置后,轉換成熱門,具體內容詳情大家跟隨小編一起通過本文學習吧
    2018-10-10
  • 基于vue.js實現圖片輪播效果

    基于vue.js實現圖片輪播效果

    這篇文章主要為大家詳細介紹了基于vue.js實現圖片輪播效果,vue如何實現輪播圖效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • vue實現手機端省市區(qū)區(qū)域選擇

    vue實現手機端省市區(qū)區(qū)域選擇

    這篇文章主要為大家詳細介紹了vue實現手機端省市區(qū)區(qū)域選擇,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • vue使用axios跨域請求數據問題詳解

    vue使用axios跨域請求數據問題詳解

    這篇文章主要為大家詳細介紹了vue使用axios跨域請求數據的問題,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • Vue實現大屏頁面的屏幕自適應

    Vue實現大屏頁面的屏幕自適應

    這篇文章主要為大家詳細介紹了Vue實現大屏頁面的屏幕自適應,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • Vue-admin-template?添加、跳轉子頁面問題

    Vue-admin-template?添加、跳轉子頁面問題

    這篇文章主要介紹了Vue-admin-template?添加、跳轉子頁面問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue使用map代替Aarry數組循環(huán)遍歷的方法

    vue使用map代替Aarry數組循環(huán)遍歷的方法

    這篇文章主要介紹了vue使用map代替Aarry數組循環(huán)遍歷的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04

最新評論