实现简单的数据绑定和渲染

目标

指定一个Vue实例,可以渲染出对应的HTML,并且当数据变动时重新渲染。
例如:

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>

结果如下:

结果

思路

  1. 根据el属性找到对应的根元素
  2. 记录原HTML。
  3. 使用正则表达式找到需要替换的部分,然后根据data属性对{{}}内的字符串进行求值。把修改后的HTML赋值回去。
  4. 监视数据的变动,如果数据有改变,就重复上一步。

其中前几步实现都不难,最主要的部分就是第四步。
这里需要实现一个Observer类,它接受一个对象作为监视的值。然后当对象产生变化时,需要发出消息。

怎么发出消息?

  • 实现一个EventHandler类,有一个属性$listeners,2个函数$on$emit,前者对于某个事件把指定的函数存入对应的监听器中,后者对于某个事件调用其对应的所有监听器。(发布-订阅模式)

怎么监视属性的修改?

  • 遍历对象的每个属性,使用Object.defineProperty设置属性的getter,如果值改变了就调用$emit方法。

如果对象内还嵌套对象怎么办?

  • 使用递归的方法,遍历每个对象的每个属性(实际做的时候没考虑继承的),如果属性是一个对象则继续new Observer

如果属性修改后的值是对象怎么办?

  • 检测属性修改后的类型,如果是对象则也要new Observer

内层属性的修改如何传递到上层?

  • 例如user.location是一个对象,为location的每个属性$on一个函数,内容是在user$emit location,这样就实现了层层上传。

样例地址

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,086评论 0 29
  • 对不起,这个是我的真实心声。 我竟然会喜欢上不同的人,应该是在不同的地点、不同的时间里。 会喜欢上已经有了女朋友的...
    兰因阅读 467评论 0 0
  • (1)随心所欲,不逾矩。这真是最高境界了。已经摸透了社会的游戏规则,熟知了人性的善恶。然后,穿梭其中,不妨碍谁,也...
    懂懂书童阅读 198评论 0 0
  • 文/幽幽淡墨痕 你是我心底的秘密。我对春夏秋冬深情地说,大海感动得拍打翻滚的浪花。纷飞,纷飞,如花瓣在田间起舞。 ...
    幽幽淡墨痕阅读 420评论 0 1
  • 一年一度的双十一购物狂欢终于落下帷幕,阿里巴巴又一次独占鳌头,刷新了记录,24小时成交额高达1207亿元,这样的增...
    补拙莫如勤LV阅读 208评论 0 0