亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用proxy實現(xiàn)一個更優(yōu)雅的vue【推薦】

 更新時間:2018年06月19日 11:24:30   作者:noahlam  
Proxy 用于修改某些操作的默認(rèn)行為,等同于在語言層面做出修改,所以屬于一種“元編程”。這篇文章主要介紹了用proxy實現(xiàn)一個更優(yōu)雅的vue,需要的朋友可以參考下

如果你有讀過Vue的源碼,或者有了解過Vue的響應(yīng)原理,那么你一定知道Object.defineProperty(), 那么你也應(yīng)該知道,Vue 2.x里,是通過 遞歸 + 遍歷 data 對象來實現(xiàn)對數(shù)據(jù)的監(jiān)控的, 你可能還會知道,我們使用的時候,直接通過數(shù)組的下標(biāo)給數(shù)組設(shè)置值,不能實時響應(yīng),是因為Object.defineProperty() 無法監(jiān)控到數(shù)組下標(biāo)的變化,而我們平常所用的數(shù)組方法 push , pop , shift , unshift , splice , sort , reverse , 其實不是真正的數(shù)組方法,而是被修改過的,這些都是因為 Object.defineProperty() 提供的能力有限,無法做到完美。

網(wǎng)上看過很多關(guān)于Vue的源碼解讀或者實現(xiàn)一個簡易版的Vue的教程,還都是用 Object.defineProperty (大概是為兼容性考慮吧), 而 Object.defineProperty() 確實存在諸多限制, 據(jù)說Vue的3.x版本會改用Proxy,那么今天我們就先來嘗嘗鮮,用Proxy實現(xiàn)一個簡單版的Vue

proxy 介紹

Proxy 用于修改某些操作的默認(rèn)行為,等同于在語言層面做出修改,所以屬于一種“元編程”(meta programming),即對編程語言進(jìn)行編程。

Proxy 可以理解成,在目標(biāo)對象之前架設(shè)一層“攔截”,外界對該對象的訪問,都必須先通過這層攔截,因此提供了一種機制,可以對外界的訪問進(jìn)行過濾和改寫。Proxy 這個詞的原意是代理,用在這里表示由它來“代理”某些操作,可以譯為“代理器”。

以上引用內(nèi)容來自阮一峰的es6教程的Proxy章節(jié) 原文地址請戳這里。

我們來看看如何用Proxy去定義一個監(jiān)聽數(shù)據(jù)的函數(shù)

定義 observe

_observe (data){
 var that = this
 // 把代理器返回的對象存到 this.$data 里面
 this.$data = new Proxy(data, {
 set(target,key,value){
 // 利用 Reflect 還原默認(rèn)的賦值操作
 let res = Reflect.set(target,key,value)
 // 這行就是監(jiān)控代碼了
 that.handles[key].map(item => {item.update()})
 return res
 }
 })
}

當(dāng)觸發(fā)set的時候,就會執(zhí)行 that.handles[key].map(item => {item.update()}) ,這句代碼的作用就是執(zhí)行 該屬性名下的所有 "監(jiān)視器"

那么,監(jiān)視器怎么來的呢? 請繼續(xù)看以下代碼

定義 compile

_compile (root){
 const nodes = Array.prototype.slice.call(root.children)
 let data = this.$data
 nodes.map(node => {
  // 如果不是末尾節(jié)點,就遞歸
  if(node.children.length > 0) this._complie(node)
  // 處理 v-bind 指令
  if(node.hasAttribute('v-bind')) {
  let key = node.getAttribute('v-bind')
  this._pushWatcher(new Watcher(node,'innerHTML',data,key))
  }
  // 處理 v-model 指令
  if(node.hasAttribute('v-model')) {
  let key = node.getAttribute('v-model')
  this._pushWatcher(new Watcher(node,'value',data,key))
  node.addEventListener('input',() => {data[key] = node.value})
  }
  // 處理 v-click 指令
  if(node.hasAttribute('v-click')) {
  let methodName = node.getAttribute('v-click')
  let mothod = this.$methods[methodName].bind(data)
  node.addEventListener('click',mothod)
  }
 })
 }

上面這段代碼,看起來很長,可是實際上,只做了意見很簡單的事情, 就是 "編譯" html 模板 ,把有 v-bind 、 v-model 、 v-click 都給加上對應(yīng)的 通知 和 監(jiān)控

1.通知就是 this._pushWatcher(...) , 相當(dāng)于是安裝一個監(jiān)聽器,這樣只要 this.$data 有發(fā)生 set 操作的話,就會執(zhí)行 this._pushWatcher 括號里面?zhèn)鞯暮瘮?shù),來通知節(jié)點更新數(shù)據(jù)

2.監(jiān)控就是 node.addEventListener(...) 監(jiān)聽相應(yīng)的事件,然后執(zhí)行對應(yīng)的 watcher 或者 methods

this._pushWatcher 又做了什么呢?

_pushWatcher (watcher) {
 if (!this._binding[watcher.key]) this._binding[watcher.key] = []
 this._binding[watcher.key].push(watcher)
 }

這個就更簡單了,如果 this._binding[watcher.key] 為空,就初始化,然后向里面添加一個 監(jiān)聽器

最后,我們再來看看,監(jiān)聽器是怎么實現(xiàn)的

定義 Watcher

class Watcher {
 constructor (node,attr,data,key) {
 this.node = node
 this.attr = attr
 this.data = data
 this.key = key
 }
 update () {
 this.node[this.attr] = this.data[this.key]
 }
 }

Watcher 是一個類,只有一個方法,就是更新數(shù)據(jù),怎么知道要更新哪個節(jié)點,更新為什么數(shù)據(jù)呢? 在實例化(new)的時候,傳的參數(shù)就是定義這些的

這樣,我們就實現(xiàn)初步的雙向綁定了,整個代碼大概只有50行。其實還可以更少, 但是更少的話,就是繼續(xù)閹割功能了(雖然目前實現(xiàn)的也是嚴(yán)重閹割版的), 但是我覺得實現(xiàn)這些,剛好可以不多不少幫我我們理解vue的本質(zhì)。

最后

本文最終實現(xiàn)代碼已經(jīng)放在 github 上,想要直接看效果的同學(xué),可以上去直接copy,運行。

如果覺得本文對您有用,請給本文的github 加個star,萬分感謝

另外, github 上還有其他一些關(guān)于前端的教程和組件,有興趣的童鞋可以看看,你們的支持就是我最大的動力。

總結(jié)

以上所述是小編給大家介紹的使用proxy實現(xiàn)一個更優(yōu)雅的vue,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Vue中狀態(tài)管理器(vuex)詳解以及實際應(yīng)用場景

    Vue中狀態(tài)管理器(vuex)詳解以及實際應(yīng)用場景

    Vuex是一個專為Vue.js應(yīng)用程序開發(fā)的狀態(tài)管理模式,下面這篇文章主要給大家介紹了關(guān)于Vue中狀態(tài)管理器(vuex)詳解以及實際應(yīng)用場景的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • vue中如何實現(xiàn)后臺管理系統(tǒng)的權(quán)限控制的方法示例

    vue中如何實現(xiàn)后臺管理系統(tǒng)的權(quán)限控制的方法示例

    這篇文章主要介紹了vue中如何實現(xiàn)后臺管理系統(tǒng)的權(quán)限控制的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • vue.js實現(xiàn)簡單計時器功能

    vue.js實現(xiàn)簡單計時器功能

    這篇文章主要為大家詳細(xì)介紹了vue.js實現(xiàn)簡單計時器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vue+導(dǎo)航錨點聯(lián)動-滾動監(jiān)聽和點擊平滑滾動跳轉(zhuǎn)實例

    vue+導(dǎo)航錨點聯(lián)動-滾動監(jiān)聽和點擊平滑滾動跳轉(zhuǎn)實例

    今天小編就為大家分享一篇vue+導(dǎo)航錨點聯(lián)動-滾動監(jiān)聽和點擊平滑滾動跳轉(zhuǎn)實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue使用dagre-d3畫流程圖的完整代碼

    vue使用dagre-d3畫流程圖的完整代碼

    這篇文章主要給大家介紹了關(guān)于vue使用dagre-d3畫流程圖的完整代碼,dagre-d3.js是一個用于在Vue.js框架中實現(xiàn)DAG(有向無環(huán)圖)可視化的庫,它結(jié)合了vue.js、dagre和d3.js這三個庫的功能,需要的朋友可以參考下
    2024-02-02
  • 詳細(xì)聊聊vue中組件的props屬性

    詳細(xì)聊聊vue中組件的props屬性

    父子組件之間的通信就是props down,events up,父組件通過屬性props向下傳遞數(shù)據(jù)給子組件,子組件通過事件events 給父組件發(fā)送消息,這篇文章主要給大家介紹了關(guān)于vue中組件的props屬性的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • vue實現(xiàn)簡單的分頁功能

    vue實現(xiàn)簡單的分頁功能

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)簡單的分頁功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Vue3+antDesignVue實現(xiàn)表單校驗的方法

    Vue3+antDesignVue實現(xiàn)表單校驗的方法

    這篇文章主要為大家詳細(xì)介紹了基于Vue3和antDesignVue實現(xiàn)表單校驗的方法,文中的示例代碼講解詳細(xì),具有一定的參考價值,需要的小伙伴可以了解下
    2024-01-01
  • Vue導(dǎo)入excel文件的兩種方式(form表單和el-upload)

    Vue導(dǎo)入excel文件的兩種方式(form表單和el-upload)

    最近開發(fā)遇到一個點擊導(dǎo)入按鈕讓excel文件數(shù)據(jù)導(dǎo)入的需求,下面這篇文章主要給大家介紹了關(guān)于Vue導(dǎo)入excel文件的兩種方式,分別是form表單和el-upload兩種方法,需要的朋友可以參考下
    2022-11-11
  • 在vue中獲取wangeditor的html和text的操作

    在vue中獲取wangeditor的html和text的操作

    這篇文章主要介紹了在vue中獲取wangeditor的html和text的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10

最新評論