一、元数据传递
1)配置inputs,接收外部传来的参数:
在inputs里配置输入属性,宿主同过这个属性就能把数据传进来。
示例如下:
@Component({
selector: 'test-component',
template: `{{inputValue}}`,
inputs: ['inputsValue']
})
export class TestComponent {
private inputsValue;//注意,要在组建内声明,才能使用
}
宿主通过“[输入属性]=输入值”的方式传值,给属性打上中括号代表输入。以上面例子为例,其父组件调用方式如下:
@Component({
selector: 'parent-component',
template: `
})
export class ParentComponent {
private data = 'Hello InputValue~!';
}
当然,如果不配置元数据,我们还可以在组件类中用“@Inputs() inputsValue”声明,效果一样;我们还可以编写“setter”函数对输入的数据进行加工过滤,这里不做细讲。
2)配置outputs,给父组件传递数据:
outputs是利用自定义事件的机制给父组件传递数据;元数据配置与inputs相似,只是组件类中要给输出属性创建EventEmitter实例。
示例如下:
@Component({
selector: 'test-component',
template: ``,
outputs: '[outputValue]'
})
export class TestComponent {
public outputValue = new EventEmmitter;
private clickToSend() {
this.outputValue.emit('Hello OutputValue~!');//注意,自定义事件必须要借助异步程序执行发布函数;异步程序有事件、前后端数据交互、延时函数。
}
}
outputs相当于给组件声明了一个自定义事件,父组件绑定该事件就能与输出机制建立联系,输出数据就是事件对象。
以上面例子为例,父组件示例如下:
@Component({
selector: 'parent-component',
template: `
})
export class ParentComponent {
private getValue(event) {
console.log(event);//Hello OutputValue~!
}
}
同样,你也可以用@Output来声明,这里不做细讲。
二、单例模块传递
JavaScript传值策略是:基本类型数据传数据副本,对象类型数据传对象引用。Angular2各模块注入Module中,只要在Module作用域范围,这些模块再通过依赖注入方式注入到别的模块,依赖的模块是单例的。
我们可以利用对象传引用的特性,达到组件间传递数据的目的。
比如我想将数据传给子组件,只需在子组件构造器中注入该组件,该组件由于是单例的,那么一方改动另一方能实时访问到。
示例如下:
//父组件:
@Component({
selector: 'parent-component',
template: `
{{value}}
Parent Value...