国产人伦视频在线观看_欧美福利视频午夜福利_日本免费三级黄色网址_re99热在线观看精品_在线观看水蜜桃小心视频网站_亚洲国产欧美一区二区麻豆_久久精品国产69精品亚洲_农村女人一级毛片农村妇女_日韩不卡免费av_毛片无码高潮喷液视频

當(dāng)前位置:首頁(yè) > 軟件開(kāi)放 > 正文內(nèi)容

Vue的響應(yīng)式原理(vue響應(yīng)式原理簡(jiǎn)書)

軟件開(kāi)放2年前 (2023-03-07)1261

本篇文章給大家談?wù)刅ue的響應(yīng)式原理,以及vue響應(yīng)式原理簡(jiǎn)書對(duì)應(yīng)的知識(shí)點(diǎn),希望對(duì)各位有所幫助,不要忘了收藏本站喔。

本文目錄一覽:

vue2響應(yīng)式原理總結(jié)

vue組件實(shí)例化時(shí),會(huì)對(duì)data屬性深度遍歷(遇到數(shù)組或者對(duì)象)為每一個(gè)屬性添加數(shù)據(jù)劫持。數(shù)據(jù)劫持就是使用Object.defineProperty(de fai in pro pu tei)方法添加get/set方法。

在這個(gè)過(guò)程中會(huì)實(shí)例化一個(gè)Dep類。

1.在get攔截器里觸發(fā)dep實(shí)例的depend方法,進(jìn)行依賴收集,實(shí)質(zhì)是在dep的實(shí)例屬性sub數(shù)組中添加依賴這個(gè)屬性的watcher實(shí)例。

2.在set攔截器里觸發(fā)dep實(shí)例的notify方法,對(duì)收集到的所有依賴派發(fā)更新,(watcher的update方法)

vue組件實(shí)例化時(shí)會(huì)實(shí)例化一個(gè)渲染watcher,渲染watcher實(shí)例化過(guò)程會(huì)做兩件事情。

1.創(chuàng)建vnode,在這個(gè)過(guò)程中,訪問(wèn)了data屬性,觸發(fā)了get方法,完成了依賴收集。

2.觸發(fā)了子組件的實(shí)例化,子組件實(shí)例化又會(huì)重復(fù)上述數(shù)據(jù)劫持的過(guò)程。

這個(gè)過(guò)程就是對(duì)組件樹的深度遍歷。

結(jié)合組件生命周期來(lái)看整個(gè)過(guò)程,父組件會(huì)先觸發(fā)created鉤子,子組件后觸發(fā)created鉤子。而子組件mouted鉤子會(huì)先執(zhí)行,父組件的mouted鉤子后執(zhí)行。

分步驟記憶

1、實(shí)現(xiàn)頁(yè)面不刷新的原理

2、頁(yè)面視圖刷新的原理

實(shí)現(xiàn)頁(yè)面不刷新

1.hash

2.history

3.abstract:支持所有 JavaScript 運(yùn)行環(huán)境,如 Node.js 服務(wù)器端。如果發(fā)現(xiàn)沒(méi)有瀏覽器的 API,路由會(huì)自動(dòng)強(qiáng)制進(jìn)入這個(gè)模式。

1.hash(哈希模式),#符號(hào)后邊是瀏覽器行為,在改變的時(shí)候不對(duì)頁(yè)面進(jìn)行刷新(重新請(qǐng)求URL)(監(jiān)聽(tīng)hashChange事件)

2.history模式,H5新增了pushState,replaceState連個(gè)新API,可以修改歷史記錄卻不會(huì)使瀏覽器刷新頁(yè)面。

視圖更新原理

其原理就是vue的響應(yīng)式更新dom的原理,m = v

m是數(shù)據(jù),也就是在vue-router install時(shí)在根組件(root vue component)添加了_route屬性,在匹配到對(duì)應(yīng)路由后更新了_route屬性值,繼而觸發(fā)了該屬性值的渲染watcher,在繼而觸發(fā)dom更新。

兩種模式的不同

1.部署時(shí),history模式需要服務(wù)端處理所有可能的路徑(例如配置nginx的配置文件),防止出現(xiàn)404。哈希模式則不需要。

2.URL表示不同。

v-model指令就是 v-bind:value 和 @input 的語(yǔ)法糖。

它即可以支持原生表單元素,也可以支持自定義組件

在自定義組件中其實(shí)際是這樣的:

它的實(shí)現(xiàn)通過(guò)自定義render函數(shù), 緩存了 vnode

Vue 在更新 DOM 時(shí)是異步執(zhí)行的,只要偵聽(tīng)到數(shù)據(jù)變化,Vue 將開(kāi)啟一個(gè)隊(duì)列,并緩沖在同一事件循環(huán)中發(fā)生的所有數(shù)據(jù)變更。

如果同一個(gè) watcher 被多次觸發(fā),只會(huì)被推入到隊(duì)列中一次。在緩沖時(shí)會(huì)去除重復(fù)數(shù)據(jù)避免不必要的計(jì)算和 DOM 操作。

$nextTick(cb) 目的是在DOM 更新完成后傳入的回調(diào)函數(shù)再被調(diào)用。

Vue3.0 響應(yīng)式原理

Vue3 使用 Proxy 對(duì)象重寫響應(yīng)式系統(tǒng),這個(gè)系統(tǒng)主要有以下幾個(gè)函數(shù)來(lái)組合完成的:

1、reactive:

接收一個(gè)參數(shù),判斷這參數(shù)是否是對(duì)象。不是對(duì)象則直接返回這個(gè)參數(shù),不做響應(yīng)式處理

創(chuàng)建攔截器對(duì)象 handler, 設(shè)置 get/set/deleteProperty

get

收集依賴(track)

返回當(dāng)前 key 的值。

如果當(dāng)前 key 的值是對(duì)象,則為當(dāng)前 key 的對(duì)象創(chuàng)建攔截器 handler, 設(shè)置 get/set/deleteProperty

如果當(dāng)前的 key 的值不是對(duì)象,則返回當(dāng)前 key 的值

set

設(shè)置的新值和老值不相等時(shí),更新為新值,并觸發(fā)更新(trigger)

deleteProperty

當(dāng)前對(duì)象有這個(gè) key 的時(shí)候,刪除這個(gè) key 并觸發(fā)更新(trigger)

返回 Proxy 對(duì)象

2、effect: 接收一個(gè)函數(shù)作為參數(shù)。作用是:訪問(wèn)響應(yīng)式對(duì)象屬性時(shí)去收集依賴

3、track:

接收兩個(gè)參數(shù):target 和 key

如果沒(méi)有 activeEffect,則說(shuō)明沒(méi)有創(chuàng)建 effect 依賴

如果有 activeEffect,則去判斷 WeakMap 集合中是否有 target 屬性,

WeakMap 集合中沒(méi)有 target 屬性,則 set(target, (depsMap = new Map()))

WeakMap 集合中有 target 屬性,則判斷 target 屬性的 map 值的 depsMap 中是否有 key 屬性

depsMap 中沒(méi)有 key 屬性,則 set(key, (dep = new Set()))

depsMap 中有 key 屬性,則添加這個(gè) activeEffect

4、trigger:

判斷 WeakMap 中是否有 target 屬性

WeakMap 中沒(méi)有 target 屬性,則沒(méi)有 target 相應(yīng)的依賴

WeakMap 中有 target 屬性,則判斷 target 屬性的 map 值中是否有 key 屬性,有的話循環(huán)觸發(fā)收集的 effect()

能說(shuō)說(shuō)vue的響應(yīng)式原理嗎?

Vue 是一個(gè) MVVM 框架,核心是雙向數(shù)據(jù)綁定,VM(視圖模型)是作為 V(視圖) 和 M(模型)的橋梁。下面是對(duì) Vue 響應(yīng)式(雙向數(shù)據(jù)綁定)的理解,如果錯(cuò)誤盡請(qǐng)指出,一起交流,共同進(jìn)步。

Vue響應(yīng)式原理核心是 數(shù)據(jù)劫持,采用 ES5 的 object.defineproperty 的 getter 和 setter 方法。從一個(gè)例子出發(fā):

首先,在Vue初始化階段,通過(guò) observer 對(duì) data 中的屬性進(jìn)行遞歸的劫持,包括 name、job_ undergo、a、b等

在 get階段也就是初始化視圖時(shí),為每一個(gè)劫持的屬性分配一個(gè) 依賴收集器,主要收集當(dāng)前屬性的觀察者對(duì)象,例子中 name 屬性在模板中有兩處被使用,那么 name 屬性的依賴收集器中就存放兩個(gè)觀察者對(duì)象

當(dāng)點(diǎn)擊按鈕時(shí),將 name 修改為 lisi 時(shí),會(huì)觸發(fā) observer 的 setter 函數(shù),將 value 更新為 lisi 最新值,然后通知依賴收集器數(shù)據(jù)發(fā)生了更新。

依賴收集就是發(fā)布訂閱模式,依賴收集器會(huì)通知所有的觀察者對(duì)象,當(dāng)前name 屬性有兩個(gè)觀察者對(duì)象。

觀察者對(duì)象調(diào)用對(duì)應(yīng)的回調(diào)函數(shù)進(jìn)行相關(guān)的處理和DOM更新

以上是純響應(yīng)式原理的分析和總結(jié),下面配一張流程圖:

vue數(shù)組響應(yīng)式原理

vue2中Object.defineProperty響應(yīng)式只對(duì)對(duì)象有效,對(duì)數(shù)組無(wú)效,所以對(duì)數(shù)組做額外處理。我們知道,會(huì)改變數(shù)組本身的方法只有7個(gè):sort, push, pop, slice, splice, shift, unshift,所以可以通過(guò)重寫這些方法來(lái)達(dá)到數(shù)組響應(yīng)式

解決方案:

1. 找到數(shù)組原型

2. 覆蓋那些能夠修改數(shù)組的更新方法,讓他們?cè)谛薷臄?shù)組同時(shí),還可以通知更新

3. 將得到的新的原型設(shè)置到數(shù)組實(shí)例原型上

4. 對(duì)數(shù)組內(nèi)部元素實(shí)現(xiàn)響應(yīng)式

// 實(shí)現(xiàn)數(shù)組響應(yīng)式// 1. 替換數(shù)組原型中7個(gè)方法constoriginalProto=Array.prototype// 克隆體原數(shù)組原型constarrayProto=Object.create(originalProto)// 可修改數(shù)組的7個(gè)方法 , 'sort'constchangeMethods=['push','pop','shift','unshift','slice','splice','sort']//? 2. 在克隆的原型上,覆蓋那些能夠修改數(shù)組的更新方法,讓他們?cè)谛薷臄?shù)組同時(shí),還可以通知更新changeMethods.forEach(method={arrayProto[method]=function(){// 進(jìn)行原始操作originalProto[method].apply(this,arguments)// 覆蓋操作:增加更新通知console.log(`數(shù)組正在執(zhí)行${method}方法`);}})// 對(duì)象響應(yīng)化functiondefineReactive(obj,key,value){Object.defineProperty(obj,key,{get(){console.log('獲取'+key);returnvalue},set(newVal){if(newVal!==value){// console.log(newVal);// console.log(JSON.stringify(obj[key]));console.log(`正在改變${key}值:從${obj[key]}變?yōu)?{newVal}`)value=newVal}}})}functionobserver(obj){// 不是對(duì)象或者為null,不做響應(yīng)式,結(jié)束if(typeofobj!=='object'||obj===null)return;// 如果是數(shù)組,修改其實(shí)例的原型if(Array.isArray(obj)){// 3. 將得到的新的原型設(shè)置到數(shù)組實(shí)例原型上obj.__proto__=arrayProto// 4. 對(duì)數(shù)組內(nèi)的元素,同樣進(jìn)行響應(yīng)化for(leti=0;iobj.length;i++){// console.log(obj[i]);observer(obj[i])}// 如果是對(duì)象}else{Object.keys(obj).forEach(key={console.log(obj,key,obj[key]);defineReactive(obj,key,obj[key])})}}obj=[{a:1},2,7,5,3]observer(obj)obj.push(4)// 數(shù)組正在執(zhí)行push方法obj.pop()// 數(shù)組正在執(zhí)行pop方法obj[0].a=2// 獲取a? ? // 正在改變a值:從1變?yōu)?obj.sort()// 數(shù)組正在執(zhí)行sort方法console.log(obj);// [ 2, 3, 5, 7, { a: [Getter/Setter] } ]console.log(obj[4].a);// 獲取a? // 2

鏈接:

vue2數(shù)據(jù)響應(yīng)式原理

vue2響應(yīng)式原理由 Observer 類, Dep 類和 Watcher 類互相調(diào)用實(shí)現(xiàn), Observer 類是把一個(gè)普通的object類變成每一層都能相應(yīng)的類, Dep 類的作用是添加,移除,通知和收集訂閱者, Watcher 類是訂閱者,主要功能是把當(dāng)數(shù)據(jù)改變的時(shí)候,去調(diào)用回調(diào)函數(shù),修改dom節(jié)點(diǎn)

那么是怎么實(shí)現(xiàn)響應(yīng)式的呢,首先是一個(gè)函數(shù),要先轉(zhuǎn)換為可響應(yīng)的,那就需要用到 Observer 類

這個(gè) observe 函數(shù)就是對(duì) Observer 類做多了一層封裝

而 Observer 類是通過(guò) Object.defineProperty 來(lái)監(jiān)控?cái)?shù)據(jù)的獲取和改變的

關(guān)鍵在于 defineReactive 方法,這個(gè)方法是對(duì) Object.defineProperty 做了一層封裝,并且對(duì)對(duì)象的每一層做遞歸調(diào)用,實(shí)現(xiàn)了每一層都有響應(yīng)監(jiān)控

但是是怎么知道現(xiàn)在要保存哪一個(gè) Watcher 實(shí)例到訂閱者數(shù)組里面的呢?其實(shí)就是用了這個(gè) Dep.target , Dep.target 相當(dāng)于 window.target ,全局只有一個(gè),全局也能訪問(wèn)

首先得先講一講 Watcher 類,我們先回到上面的index.js,對(duì)象要讓 Watcher 類進(jìn)行監(jiān)聽(tīng),而 Watcher 有3個(gè)參數(shù),第一個(gè)是監(jiān)聽(tīng)的對(duì)象,第二個(gè)是監(jiān)聽(tīng)的屬性,比如 a.b.c.d ,第三個(gè)是屬性改變后觸發(fā)的回調(diào)函數(shù)

先來(lái)講一下 parsePath ,這個(gè)在工具類里,作用是訪問(wèn) a.b.c.d 這種鏈?zhǔn)綄傩?/p>

首先是觸發(fā)了 Watcher 的 get() 方法,把當(dāng)前實(shí)例保存在了 Dep.target 里面

然后在調(diào)用 parsePath 獲取屬性值的過(guò)程中,會(huì)挨個(gè)訪問(wèn)響應(yīng)對(duì)象的屬性,就會(huì)觸發(fā)相應(yīng)的 getter ,我們回到 defineReactive.js ,可以發(fā)現(xiàn)這時(shí)候相應(yīng)屬性的 getter 就會(huì)把 Dep.target 也就是相應(yīng)的 Watcher 的實(shí)例保存在了 Dep 類的訂閱者數(shù)組里面

最后,在改變屬性的時(shí)候,相應(yīng)屬性的 setter 就會(huì)通知之前已經(jīng)保存的訂閱者數(shù)組,遍歷觸發(fā)回調(diào)

關(guān)于Vue的響應(yīng)式原理和vue響應(yīng)式原理簡(jiǎn)書的介紹到此就結(jié)束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關(guān)注本站。

掃描二維碼推送至手機(jī)訪問(wèn)。

版權(quán)聲明:本文由飛速云SEO網(wǎng)絡(luò)優(yōu)化推廣發(fā)布,如需轉(zhuǎn)載請(qǐng)注明出處。

本文鏈接:http://mbtw.com.cn/post/11364.html

“Vue的響應(yīng)式原理(vue響應(yīng)式原理簡(jiǎn)書)” 的相關(guān)文章

移動(dòng)終端軟件開(kāi)發(fā)(移動(dòng)終端軟件開(kāi)發(fā)實(shí)驗(yàn)報(bào)告)

移動(dòng)終端軟件開(kāi)發(fā)(移動(dòng)終端軟件開(kāi)發(fā)實(shí)驗(yàn)報(bào)告)

本篇文章給大家談?wù)勔苿?dòng)終端軟件開(kāi)發(fā),以及移動(dòng)終端軟件開(kāi)發(fā)實(shí)驗(yàn)報(bào)告對(duì)應(yīng)的知識(shí)點(diǎn),希望對(duì)各位有所幫助,不要忘了收藏本站喔。 本文目錄一覽: 1、軟件工程(移動(dòng)終端軟件開(kāi)發(fā)) 是什么?干嘛的?學(xué)什么? 2、計(jì)算機(jī)網(wǎng)絡(luò)技術(shù)(移動(dòng)終端軟件開(kāi)發(fā))大概是干什么的? 3、如何開(kāi)發(fā)一個(gè)移動(dòng)終端app軟件...

pycharm圣誕樹源碼教程(圣誕樹代碼Python)

pycharm圣誕樹源碼教程(圣誕樹代碼Python)

今天給各位分享pycharm圣誕樹源碼教程的知識(shí),其中也會(huì)對(duì)圣誕樹代碼Python進(jìn)行解釋,如果能碰巧解決你現(xiàn)在面臨的問(wèn)題,別忘了關(guān)注本站,現(xiàn)在開(kāi)始吧!本文目錄一覽: 1、pycharm中的圣誕樹怎么加動(dòng)態(tài)新圖片 2、圣誕樹python用的是什么曲線 3、如何將pycharm編寫的源代碼文件...

去水印小程序源碼springboot(去水印小程序源碼個(gè)人)

去水印小程序源碼springboot(去水印小程序源碼個(gè)人)

本篇文章給大家談?wù)勅ニ⌒〕绦蛟创aspringboot,以及去水印小程序源碼個(gè)人對(duì)應(yīng)的知識(shí)點(diǎn),希望對(duì)各位有所幫助,不要忘了收藏本站喔。 本文目錄一覽: 1、從零開(kāi)始學(xué)SpringBoot之SpringBoot WebSocket原理篇 2、Springboot初始化流程解析 3、[Sprin...

用Python設(shè)計(jì)小游戲(python設(shè)計(jì)小游戲誰(shuí)先走到17誰(shuí)就贏)

用Python設(shè)計(jì)小游戲(python設(shè)計(jì)小游戲誰(shuí)先走到17誰(shuí)就贏)

本篇文章給大家談?wù)動(dòng)肞ython設(shè)計(jì)小游戲,以及python設(shè)計(jì)小游戲誰(shuí)先走到17誰(shuí)就贏對(duì)應(yīng)的知識(shí)點(diǎn),希望對(duì)各位有所幫助,不要忘了收藏本站喔。 本文目錄一覽: 1、Python實(shí)現(xiàn)消消樂(lè)小游戲 2、用Python寫一個(gè)簡(jiǎn)單的小游戲 3、python簡(jiǎn)單小游戲代碼 怎么用Python制作簡(jiǎn)單小...

端游游戲交易平臺(tái)app排行榜(手游交易平臺(tái)app排行榜)

端游游戲交易平臺(tái)app排行榜(手游交易平臺(tái)app排行榜)

今天給各位分享端游游戲交易平臺(tái)app排行榜的知識(shí),其中也會(huì)對(duì)手游交易平臺(tái)app排行榜進(jìn)行解釋,如果能碰巧解決你現(xiàn)在面臨的問(wèn)題,別忘了關(guān)注本站,現(xiàn)在開(kāi)始吧!本文目錄一覽: 1、手游交易平臺(tái)哪個(gè)好 2、賣游戲賬號(hào)哪個(gè)平臺(tái)好? 3、手游交易平臺(tái)哪個(gè)好? 4、網(wǎng)絡(luò)游戲賬號(hào)交易平臺(tái)哪個(gè)比較好?...

中央13臺(tái)在線直播觀看高清(中央13臺(tái)在線直播觀看高清央視新聞天氣預(yù)報(bào))

中央13臺(tái)在線直播觀看高清(中央13臺(tái)在線直播觀看高清央視新聞天氣預(yù)報(bào))

今天給各位分享中央13臺(tái)在線直播觀看高清的知識(shí),其中也會(huì)對(duì)中央13臺(tái)在線直播觀看高清央視新聞天氣預(yù)報(bào)進(jìn)行解釋,如果能碰巧解決你現(xiàn)在面臨的問(wèn)題,別忘了關(guān)注本站,現(xiàn)在開(kāi)始吧!本文目錄一覽: 1、CCTV13怎么在手機(jī)上看到? 2、中央電視臺(tái)13套直播在線觀看高清漠河到長(zhǎng)沙多遠(yuǎn) 3、中央電視臺(tái)13...