實(shí)現(xiàn)簡單的數(shù)據(jù)綁定和渲染

目標(biāo)

指定一個Vue實(shí)例,可以渲染出對應(yīng)的HTML,并且當(dāng)數(shù)據(jù)變動時重新渲染。
例如:

let app = new Vue({
  el: '#app',
  data: {
    user: {
      name: 'youngwind',
      age: 25,
      location: {
        province: 'GD',
        city: 'GZ'
      },
      school: 'bupt',
      major: 'computer'
    }
  }
})
  <div id="app">
    <p>姓名:{{user.name}}</p>
    <p>年齡:{{user.age}}</p>
    <div>
      <p>省份:{{user.location.province}}</p>
      <p>城市:{{user.location.city}}</p>
    </div>
  </div>

結(jié)果如下:

結(jié)果

思路

  1. 根據(jù)el屬性找到對應(yīng)的根元素
  2. 記錄原HTML。
  3. 使用正則表達(dá)式找到需要替換的部分,然后根據(jù)data屬性對{{}}內(nèi)的字符串進(jìn)行求值。把修改后的HTML賦值回去。
  4. 監(jiān)視數(shù)據(jù)的變動,如果數(shù)據(jù)有改變,就重復(fù)上一步。

其中前幾步實(shí)現(xiàn)都不難,最主要的部分就是第四步。
這里需要實(shí)現(xiàn)一個Observer類,它接受一個對象作為監(jiān)視的值。然后當(dāng)對象產(chǎn)生變化時,需要發(fā)出消息。

怎么發(fā)出消息?

  • 實(shí)現(xiàn)一個EventHandler類,有一個屬性$listeners,2個函數(shù)$on$emit,前者對于某個事件把指定的函數(shù)存入對應(yīng)的監(jiān)聽器中,后者對于某個事件調(diào)用其對應(yīng)的所有監(jiān)聽器。(發(fā)布-訂閱模式)

怎么監(jiān)視屬性的修改?

  • 遍歷對象的每個屬性,使用Object.defineProperty設(shè)置屬性的getter,如果值改變了就調(diào)用$emit方法。

如果對象內(nèi)還嵌套對象怎么辦?

  • 使用遞歸的方法,遍歷每個對象的每個屬性(實(shí)際做的時候沒考慮繼承的),如果屬性是一個對象則繼續(xù)new Observer。

如果屬性修改后的值是對象怎么辦?

  • 檢測屬性修改后的類型,如果是對象則也要new Observer。

內(nèi)層屬性的修改如何傳遞到上層?

  • 例如user.location是一個對象,為location的每個屬性$on一個函數(shù),內(nèi)容是在user$emit location,這樣就實(shí)現(xiàn)了層層上傳。

樣例地址

https://github.com/huhk-sysu/ife-study/blob/master/vue/hw5/hw5.js

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容,還有我對于 Vue 1.0 印象不深的內(nèi)容。關(guān)于...
    云之外閱讀 5,174評論 0 29
  • 對不起,這個是我的真實(shí)心聲。 我竟然會喜歡上不同的人,應(yīng)該是在不同的地點(diǎn)、不同的時間里。 會喜歡上已經(jīng)有了女朋友的...
    蘭因閱讀 547評論 0 0
  • (1)隨心所欲,不逾矩。這真是最高境界了。已經(jīng)摸透了社會的游戲規(guī)則,熟知了人性的善惡。然后,穿梭其中,不妨礙誰,也...
    懂懂書童閱讀 215評論 0 0
  • 文/幽幽淡墨痕 你是我心底的秘密。我對春夏秋冬深情地說,大海感動得拍打翻滾的浪花。紛飛,紛飛,如花瓣在田間起舞。 ...
    幽幽淡墨痕閱讀 457評論 0 1
  • 一年一度的雙十一購物狂歡終于落下帷幕,阿里巴巴又一次獨(dú)占鰲頭,刷新了記錄,24小時成交額高達(dá)1207億元,這樣的增...
    補(bǔ)拙莫如勤LV閱讀 233評論 0 0

友情鏈接更多精彩內(nèi)容