日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

angular生命周期钩子ngOnChanges-父组件使子组件输入属性值变化时触发

發布時間:2025/3/21 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 angular生命周期钩子ngOnChanges-父组件使子组件输入属性值变化时触发 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

觸發條件:

  • 父組件使子組件輸入屬性值變化時才會調用,子組件自己改變輸入屬性的值不會調用
  • @input屬性(輸入屬性)發生變化時,會調用
  • 當輸入屬性為對象時,當對象的屬性值發生變化時,不會調用
  • 當對象的引用變化時會觸發

父組件

//app.component.html <app-child [greeting]="greeting" [user]="user"></app-child><p> 問候語:<input type="text" [(ngModel)]="greeting"></p> <p>姓名:<input type="text" [(ngModel)]="user.name"></p> <button (click)="changeUser()">change</button>//app.component.ts import { Component } from '@angular/core';@Component({selector: 'app-root',templateUrl: './app.component.html' }) export class AppComponent {public greeting: string = 'Hello';public user: { name: string } = { name: 'Tom' };//改變user的引用地址public changeUser():void{this.user = {name:'jq'}} }

子組件

//child.component.tsimport { Component, Input, OnChanges, SimpleChanges } from '@angular/core';@Component({selector: 'app-child',templateUrl: './child.component.html' }) export class ChildComponent implements OnChanges {@Input() greeting: string;@Input() user: { name: string };ngOnChanges(changes: SimpleChanges): void {console.log(changes);}
  • 改變問候語為Hello1會觸發ngOnChanges:

  • 改變姓名不會觸發ngOnChanges

  • 點擊change按鈕點擊,觸發changeUser方法改變user的引用地址,會觸發ngOnChanges:

  • 總結

    以上是生活随笔為你收集整理的angular生命周期钩子ngOnChanges-父组件使子组件输入属性值变化时触发的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。