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

純JS如何實(shí)現(xiàn)vue.js下的雙向綁定功能

 更新時(shí)間:2021年06月22日 09:06:48   作者:頭疼腦脹的代碼搬運(yùn)工  
對于vue下的雙向綁定功能,個(gè)人理解為在處理邏輯的過程中緩存了大量的node對象,node對象可以是html標(biāo)簽、文本內(nèi)容。既然選擇了緩存這些對象,那么在用的過程中哪里需要改變就把node拿出來,進(jìn)行標(biāo)簽屬性的變更或者文本內(nèi)容的修改。本文主要講了如何實(shí)現(xiàn)雙向綁定

看下面截圖

這是一個(gè)普通的html文件,也并沒有引入vue.js,是不是在代碼中看到有些熟悉的地方?比如:"v-model","v-on:click",還有常用的“雙花括號{{}}”賦值語句。

首先說一下實(shí)現(xiàn)雙向綁定的思路:

一、創(chuàng)建一個(gè)自定義vue js對象,例如上面的wslVue 對象,初始化方法里面需要的參數(shù)有:(1)需要掛載到的dom對象id、(2)自定義vue對象的data屬性(json對象)、(3)后面添加了一個(gè)模擬掛載的方法。(這里有用的就是(1)、(2)參數(shù),(3)參數(shù)可以當(dāng)認(rèn)為vue對象所有的初始化工作完成后可以進(jìn)行渲染(掛載)了方法回調(diào))。

二、重寫vue屬性data json對象的set、get方法,同時(shí)可以為vue對象添加data下的所有屬性,重寫vue生成屬性的set、get方法,方法里直接執(zhí)行data的set、get方法(目的是可以直接用vue對象屬性的讀寫進(jìn)行dom操作)。

三、解析html,將html里面的標(biāo)簽node、文本node進(jìn)行特定重組(這里說的特定重組指的就是將vue指令,{{}} 賦值符號轉(zhuǎn)換為正常的html文檔進(jìn)行輸出),在解析過程中對每一個(gè)需要操作的node進(jìn)行緩存、綁定邏輯、添加監(jiān)聽事件(比如:input標(biāo)簽輸入)。

再說一下實(shí)現(xiàn)這些功能的js主要的方法有哪些:

一、js對象屬性的set、get方法。

二、document.createDocumentFragment html片段解析。

三、相關(guān)的正則判斷進(jìn)行html代碼片段重組。

最后需要?jiǎng)?chuàng)建哪些工具類?

一、vue對象。

二、觀察者類Watcher,保存需要操作的node節(jié)點(diǎn)和屬性變更需要做的回調(diào)方法。

三、管理所有觀察者Watcher的管理類Dep,控制數(shù)據(jù)變更相關(guān)Watcher進(jìn)行回調(diào)渲染。

實(shí)現(xiàn)vue雙向綁定

初始化vue對象方法

注釋:

1:為vue對象添加data里全部的屬性,并重寫set、get方法。

2:為vue對象添加方法管理methods對象,當(dāng)解析html獲取到v-on:click方法的時(shí)候?yàn)闃?biāo)簽添加click事件方法體。

3:這里進(jìn)行解析html,解析時(shí)遇到需要處理的node時(shí)創(chuàng)建Watcher對象,將相關(guān)node及指令保存在Watcher對象里,并把Watcher對象添加到觀察者管理類Dep集合里面。

4:初始化完成后進(jìn)行掛載,渲染完整的html到指定的dom元素上。

Compile類解析需要掛載對應(yīng)的dom

獲取全部的node節(jié)點(diǎn)

解析特定指令

標(biāo)簽元素與文本內(nèi)容判斷

這里如果是標(biāo)簽node需要解析里面的v-on和v-model指令

v-model

v-on:click

紅線處即為vue對象里methods匹配出來的方法,為當(dāng)前的node添加點(diǎn)擊事件。

這里如果是文本內(nèi)容node需要解析里面的{{}}指令。

總結(jié):這里會創(chuàng)建很多Watcher對象,對象保存了當(dāng)前vue對象、node、數(shù)據(jù)變更回調(diào),并保存在Dep管理類里,以待數(shù)據(jù)變更時(shí)直接執(zhí)行方法回調(diào)進(jìn)行渲染。

特定指令判斷

Watcher及Dep對象

最后放一張思維導(dǎo)圖

結(jié)尾:到這里基本的思路就講完了,沒有太復(fù)雜的邏輯,表達(dá)能力有限。希望對大家能有幫助,同時(shí)也接受大神們的批評指正,共同進(jìn)步。

以上就是純JS如何實(shí)現(xiàn)vue.js下的雙向綁定功能的詳細(xì)內(nèi)容,更多關(guān)于JS實(shí)現(xiàn)vue的雙向綁定的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 詳解Vue 2中的? initState 狀態(tài)初始化

    詳解Vue 2中的? initState 狀態(tài)初始化

    這篇文章主要介紹了詳解Vue 2中的initState狀態(tài)初始化,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • mockjs+vue頁面直接展示數(shù)據(jù)的方法

    mockjs+vue頁面直接展示數(shù)據(jù)的方法

    這篇文章主要介紹了mockjs+vue頁面直接展示數(shù)據(jù)的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • 基于vue實(shí)現(xiàn)多功能樹形結(jié)構(gòu)組件的示例代碼

    基于vue實(shí)現(xiàn)多功能樹形結(jié)構(gòu)組件的示例代碼

    一個(gè)優(yōu)雅展示樹形結(jié)構(gòu)數(shù)據(jù)的 Vue 組件,遞歸渲染每個(gè)節(jié)點(diǎn)及其子節(jié)點(diǎn),支持自定義顏色、文本和布局,通過獨(dú)特的樣式巧妙處理不同層級,為用戶打造豐富的視覺盛宴,文中通過代碼給大家介紹的非常詳細(xì),感興趣的同學(xué)可以自己動(dòng)手嘗試一下
    2024-02-02
  • Vue使用Element-UI實(shí)現(xiàn)分頁效果全過程

    Vue使用Element-UI實(shí)現(xiàn)分頁效果全過程

    element-ui官網(wǎng)上有分頁實(shí)現(xiàn)的功能,簡單方便又好用,也有很多分頁的樣式,你可以根據(jù)需要去選擇自己想要的樣式,下面這篇文章主要給大家介紹了關(guān)于Vue使用Element-UI實(shí)現(xiàn)分頁效果的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • vue側(cè)邊欄動(dòng)態(tài)生成下級菜單的方法

    vue側(cè)邊欄動(dòng)態(tài)生成下級菜單的方法

    今天小編就為大家分享一篇vue側(cè)邊欄動(dòng)態(tài)生成下級菜單的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 關(guān)于vue 項(xiàng)目中瀏覽器跨域的配置問題

    關(guān)于vue 項(xiàng)目中瀏覽器跨域的配置問題

    這篇文章主要介紹了vue 項(xiàng)目中瀏覽器跨域的配置問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Vue中使用 setTimeout() setInterval()函數(shù)的問題

    Vue中使用 setTimeout() setInterval()函數(shù)的問題

    這篇文章主要介紹了Vue中使用 setTimeout() setInterval()函數(shù)的問題 ,需要的朋友可以參考下
    2018-09-09
  • Vue渲染函數(shù)詳解

    Vue渲染函數(shù)詳解

    下面小編就為大家?guī)硪黄猇ue渲染函數(shù)詳解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • Vuex的熱更替如何實(shí)現(xiàn)

    Vuex的熱更替如何實(shí)現(xiàn)

    這篇文章主要介紹了Vuex的熱更替如何實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Vue 配合eiement動(dòng)態(tài)路由,權(quán)限驗(yàn)證的方法

    Vue 配合eiement動(dòng)態(tài)路由,權(quán)限驗(yàn)證的方法

    今天小編就為大家分享一篇Vue 配合eiement動(dòng)態(tài)路由,權(quán)限驗(yàn)證的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09

最新評論