当前位置: 首页 > news >正文

哪个网站免费做简历百度地图 wordpress

哪个网站免费做简历,百度地图 wordpress,免费源码大全无用下载,旅游电子商务网站有哪些当 Angular 实例化组件类 并渲染组件视图及其子视图时#xff0c;组件实例的生命周期就开始了。生命周期一直伴随着变更检测#xff0c;Angular 会检查数据绑定属性何时发生变化#xff0c;并按需更新视图和组件实例。当 Angular 销毁组件实例并从 DOM 中移除它渲染的模板时…当 Angular 实例化组件类 并渲染组件视图及其子视图时组件实例的生命周期就开始了。生命周期一直伴随着变更检测Angular 会检查数据绑定属性何时发生变化并按需更新视图和组件实例。当 Angular 销毁组件实例并从 DOM 中移除它渲染的模板时生命周期就结束了。当 Angular 在执行过程中创建、更新和销毁实例时指令就有了类似的生命周期。 你的应用可以使用生命周期钩子方法来触发组件或指令生命周期中的关键事件以初始化新实例需要时启动变更检测在变更检测过程中响应更新并在删除实例之前进行清理。 浅灰色名字的事件在组件的生命周期中只会触发一次而绿色的随着相应的逻辑变化会多次触发。 Construction, OnChanges, OnInit, DoCheck, AfterContentInit, AfterContentChecked, AfterViewInit, AfterViewChecked, OnDestroy1 响应生命周期事件 可以通过实现一个或多个 Angular core 库中定义的生命周期钩子接口来响应组件或指令生命周期中的事件。这些钩子让你有机会在适当的时候对组件或指令实例进行操作比如 Angular 创建、更新或销毁这个实例时。 每个接口都有唯一的一个钩子方法它们的名字是由接口名再加上 ng 前缀构成的。比如OnInit 接口的钩子方法叫做 ngOnInit()。如果你在组件或指令类中实现了这个方法Angular 就会在首次检查完组件或指令的输入属性后紧接着调用它。 1.1 constructor() 每一个组件文件本质上都是一个类而constructor是ES6引入类的概念后新出现的东西是类的自身属性所以并非Angular的钩子constructor的主要作用是注入依赖这里就不展开了。这是最先被调用的一个函数。Angular 在实例化组件类时执行可以用来接收 Angular 注入的服务实例对象。 import {Component} from angular/core;// 引入服务 import {StorageService} from ../../services/storage.serviceComponent({selector: app-life,templateUrl: ./life.component.html,styleUrls: [./life.component.scss] }) export class LifeComponent {constructor(public StorageService: StorageService) {console.log(init StorageService, this.StorageService)} } 1.2 ngOnChanges() 注意这里解释一下什么是输入属性如下 Angular的输入属性是指带**有Input()**装饰器的可设置属性它允许父组件将数据值发送到子组件中。具体来说父组件通过绑定属性到子组件子组件则利用Input()装饰器来标识这是一个输入变量属性。 一旦检测到该组件或指令的输入属性发生了变化Angular 就会调用它的 ngOnChanges() 方法。这个 onChanges 范例通过监控 OnChanges() 钩子演示了这一点。 如下例子所示 父组件 app-life [parentValue]parentValue/app-life input typetext nameparentValue [(ngModel)]parentValue子组件 import {Component, Input, SimpleChanges} from angular/core;// 引入服务 import {StorageService} from ../../services/storage.serviceComponent({selector: app-life,templateUrl: ./life.component.html,styleUrls: [./life.component.scss] }) export class LifeComponent {constructor(public StorageService: StorageService) {console.log(init StorageService, this.StorageService)}Input() parentValue: string;ngOnChanges(changes: SimpleChanges) {console.log(changes)for (const propName in changes) {const chng changes[propName];const cur JSON.stringify(chng.currentValue);const prev JSON.stringify(chng.previousValue);console.log(cur , cur)console.log(prev , prev)}} } 当输入属性的值发生变化时 ngOnChanges() 方法获取了一个对象它把每个发生变化的属性名都映射到了一个SimpleChange对象该对象中有属性的当前值和前一个值。这个钩子会在这些发生了变化的属性上进行迭代并记录它们。 1.3 ngOnInit() 通常我们在这里获取数据或者设置属性值。 ngOnInit() {this.getUserDataByAPIRequest();this.setOtherData();this.age 18; } 使用 ngOnInit() 方法执行以下初始化任务 在构造函数外部执行复杂的初始化。**组件的构造应该既便宜又安全。比如你不应该在组件构造函数中获取数据。**当在测试中创建组件时或者决定显示它之前你不应该担心新组件会尝试联系远程服务器。ngOnInit()是组件获取初始数据的好地方。 你固然可以在构造函数中调用getHeroes()但那不是最佳实践。让构造函数保持简单只做最小化的初始化操作比如把构造函数的参数赋值给属性。构造函数不应该做任何事。它当然不应该调用某个函数来向远端服务比如真实的数据服务发起HTTP 请求。而是选择在 ngOnInit 生命周期钩子中调用 getHeroes()之后 Angular 会在构造出HeroesComponent 的实例之后的某个合适的时机调用 ngOnInit()。 ngOnInit(): void {this.getHeroes(); }在 Angular设置好输入属性之后设置组件。构造函数应该只把初始局部变量设置为简单的值。请记住只有在构造完成之后才会设置指令的数据绑定输入属性。如果要根据这些属性对指令进行初始化请在运行ngOnInit() 时设置它们。 ngOnChanges() 方法是你能访问这些属性的第一次机会。Angular 会在调用 ngOnInit() 之前调用 ngOnChanges()而且之后还会调用多次。但它只调用一次 ngOnInit()。 1.4 ngDoCheck() 这种情况不常见如果是新手也没必要在这上面伤脑筋只需要知道它会在ngOnInit()和每次ngOnChanges()之后调用。 ngDoCheck() {console.log(ngOnInit()和每次ngOnChanges()之后调用)}1.5 ngAfterContentInit() 它会在 Angular 初始化完该指令的所有内容之后立即调用。要点 在指令初始化完成之后它只会调用一次。可以用来处理一些初始化任务。 1.6 ngAfterContentChecked() 在默认的变更检测器对该指令下的所有内容完成了变更检测之后立即调用。 1.7 ngAfterViewInit() 简单来说就是当组件视图渲染完成后调用也就是说在这个函数执行之前是没有办法获取到HTML里面的内容的。举个例子,我们想获取视图里的一个div结点, 可以通过ViewChild, 然后尝试在ngOnInit和ngAfterViewInit中去打印。 app-life [parentValue]parentValue #lifeComponent/app-lifeimport {Component, ViewChild} from angular/core;Component({selector: app-root,templateUrl: ./app.component.html,styleUrls: [./app.component.scss] }) export class AppComponent {title firstProject;public parentValue: string parentValueViewChild(lifeComponent) lifeComponent: any;ngOnInit(): void {console.log(ngOnInit, this.lifeComponent);}ngAfterViewInit(): void {console.log(ngAfterViewInit, this.lifeComponent);} } 1.8 ngAfterViewChecked() app-life [parentValue]parentValue #lifeComponent/app-life input typetext nameparentValue [(ngModel)]parentValue import {Component, ViewChild} from angular/core;Component({selector: app-root,templateUrl: ./app.component.html,styleUrls: [./app.component.scss] }) export class AppComponent {title firstProject;public parentValue: string parentValueViewChild(lifeComponent) lifeComponent: any;ngOnInit(): void {console.log(ngOnInit, this.lifeComponent);}ngAfterViewInit(): void {console.log(ngAfterViewInit, this.lifeComponent);}ngAfterViewChecked(): void {console.log(ngAfterViewChecked, this.lifeComponent);} } 1.9 ngOnDestroy()
http://www.w-s-a.com/news/833145/

相关文章:

  • 怎样建一个自己公司的网站制作网站需要钱吗
  • 联盟网站制作wap网站制作公司
  • 美丽乡村建设发展论坛网站wordpress 仿站 教程网
  • 浙江省建设注册管理中心网站首页优设设计网站导航
  • 台州小型网站建设国内免费的建网站平台
  • 自己做网站不推广网站建设工作室发展
  • 有女人和马做网站吗宁波seo优势
  • 网站做用户记录表电商运营推广计划方案
  • 网站备案认领杭州网页设计公司招聘
  • 易签到网站开发设计做网站运营有前途吗
  • 南通网站建设心得2023必考十大时政热点
  • 苍溪建设局网站公建设计网站
  • 九歌人工智能诗歌写作网站电子商务网站建设项目书
  • 做外贸的经常浏览的三个网站律师做哪个网站好
  • 中国公路建设招标网站长沙大型网站建设公司
  • 沈阳企业网站模板建站注册电子邮箱免费注册
  • 如何做简洁网站设计企业网站排名优化方案
  • 东莞网站建设服务商做触屏网站
  • 外国网站代理音乐网站建设
  • 珠江网站建设广安广告公司
  • 高端创意网站建设网页制作咨询公司
  • 网站建设及发布的流程图wordpress文章摘要显示
  • 淮北网站网站建设省好多会员app
  • 如何查看网站的更新频率网站图片要求
  • 网站设计公司收费标准wordpress修改文章链接
  • 镇江网站建设公司网站关键词密度怎么计算的
  • c 网站开发公司的网站的设计
  • 网站建设多长时间能学会做网站猫要做端口映射吗
  • 新手做网站视频网页设计期末作品要求
  • 做网站用户充值提现郑州高端模板建站