发布于 2015-09-06 14:49:31 | 240 次阅读 | 评论: 0 | 来源: 网络整理

这一章节, 我们来看下在组件的生命周期来帮助我们理解, regularjs内部的运行机制.

new Component(options)

当你实例化组件时,将会发生以下剧情

对应的源码来源于Regularjs.js

1 options将合并原型中的 events, data

options = options || {};
options.data = options.data || {};
options.events = options.events || {};
if(this.data) _.extend(options.data, this.data);
if(this.events) _.extend(options.events, this.events);

2 将options合并到this中

由于传入了参数true, 实例化中传入的属性会覆盖原型属性.

_.extend(this, options, true);

3 解析模板

模板本身已经被解析过了(AST),这步跳过.

if(typeof template === 'string') this.template = new Parser(template).parse();

4. 根据传入的options.events 注册事件

注册事件,可以让我们无需去实现那生命的方法(init, destory等)

if(this.events){
  this.$on(this.events);
}

5* 调用config函数.

一般此函数我们会在config中预处理我们传入的数据

this.config && this.config(this.data);

6* 编译模板, 触发一次组件脏检查

这里的脏检查是为了确保组件视图正确, 到这里我们已经拥有初始化的dom元素, 你可以通过$refs来获取你标记的.


if(template){
  this.group = this.$compile(this.template, {namespace: options.namespace});
}

7* 触发$init事件, 并调用this.init方法. __

调用init之后我们不会进行自动的脏检查.

this.$emit("$init");
if( this.init ) this.init(this.data);

component.destory()

当销毁组件时,剧情就要简单的多了.

  1. 触发$destroy事件

  2. 销毁所有模板的dom节点,并且解除所有数据绑定、指令等

需要注意的是,是Regular.prototype.destory完成了这些处理, 所以永远记得在你定义的destory函数中使用this.supr(). 一个更稳妥的方案是: 永远不重写destroy, 而是注册$destory事件来完成你的回收工作.

最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务