问题:父组件中有两个tab标签,每个tab下控制各自的子组件,并且每个tab下面的数据可相互转换。
data:image/s3,"s3://crabby-images/5e15a/5e15aec868b4bdf6396eefbf5d930e7ddd751731" alt=""
如上图所示,待发布的数据和进行中的数据可相互转换。当在待发布tab中转换了一条数据为进行中时,此时切换tab为进行中并没有发现刚才转换的数据(实际上已经转换)。发现tab切换时子组件没有刷新数据,所以需要父组件主动调用子组件来刷新数据。
解决方法:
1.在父组件中声明子组件名称:#ReadyComponent,#RunningComponent
data:image/s3,"s3://crabby-images/8124e/8124e674e27050c01cf25b6848258eba941fc523" alt=""
2.在父ts中获取子组件实例以调用子组件的方法
data:image/s3,"s3://crabby-images/8a76c/8a76c9c3125223c37cbb5cbb38a3fec0cf2e83b7" alt=""
data:image/s3,"s3://crabby-images/6cbb4/6cbb47d8968cdcfdd5440849ced1577c2ec1e30a" alt=""
3.调用子组件方法以刷新数据
data:image/s3,"s3://crabby-images/43f4b/43f4b104cdc1f49508b08fd65270fd80f5bed4e8" alt=""
需要注意:用ViewChild装饰器获取的元素,在constructor和ngOnInit中是undefined,在AfterViewInit中可以获取到。
网友评论