目錄
區別一
區別二
區別三
總結
首頁 web前端 js教程 Angular開發問題記錄:元件拿不到@Input輸入屬性

Angular開發問題記錄:元件拿不到@Input輸入屬性

Dec 09, 2022 pm 08:17 PM
angular.js

最近在工作中實作一個feature的時候,碰到一個小問題:Angular元件拿不到@Input輸入屬性的問題,儘管對這些問題都比較了解,但是找問題是需要一個過程的,所以還是把這個問題總結記錄了下來。

Angular開發問題記錄:元件拿不到@Input輸入屬性

【相關教學推薦:《angular教學》】

我需要給一個Component設定一個輸入屬性@Input,好了,直接上程式碼,沒有什麼難度。

原始程式碼是這樣的

@Component({
	selector: 'my-menu',
	templateUrl: './main-menu.widget.html'
})
export class MyMenuWidget {
  data: any[];
  
  ...

    constructor(...) {
       this._changesSubscription = this._service.changes.pipe(
            map((data: any[]) => {
                    ...
                    return data;
            })
        ).subscribe((data: any[]) => {
            this.data = data;
        });
    }

  ...
}
登入後複製

新增一個輸入屬性:

@Component({
	selector: 'my-menu',
	templateUrl: './main-menu.widget.html'
})
export class MyMenuWidget {
  @Input() isMainMenu: boolean = false;

  data: any[];
  
  ...

    constructor(...) {
        this._changesSubscription = this._service.changes.pipe(
                map((data: any[]) => {
                        ...
                        return data;
                })
        ).subscribe((data: any[]) => {
            if (this.isMainMenu) {
               this.data = data.filter((d: any) => d.ID === 233);
            }
            else {
              this.data = data;
            }
        });
    }

  ...
}
登入後複製

使用起來

<my-menu [isMainMenu]="mainMenu"></my-menu>
登入後複製

接著發現MyMenuWidget裡的輸入屬性isMainMenu總是拿不到值,哪裡拼字有問題嗎?檢查了一下,發現完全沒有問題,但就是拿不到值。

定睛一看,啊啊啊? ? ? ,對一個Observable的訂閱居然寫在建構子裡了! ! !雖然這樣寫在一些場景下是可以正常運作的,不影響程式碼功能,但是這種寫法很不規範,就像上面例子中的程式碼一樣,造成了問題。所以,平常開發過程中, 不建議去這麼寫,那正確的寫法是什麼呢?

上程式碼。

@Component({
	selector: &#39;my-menu&#39;,
	templateUrl: &#39;./main-menu.widget.html&#39;
})
export class MyMenuWidget {
  @Input() isMainMenu: boolean = false;

  data: any[];
  
  ...
  
  constructor(...) {
     ...
  }
  
    ngOnInit() {
        this._changesSubscription = this._service.changes.pipe(
            map((data: any[]) => {
                ...
                return data;
            })
        ).subscribe((data: any[]) => {
            if (this.isMainMenu) {
                    this.data = data.filter((d: any) => d.ID === 233);
            }
            else {
                this.data = data;
            }
        });
    }

  ...
}
登入後複製

那麼問題來了,為什麼同樣的程式碼放ngOnInit裡面就可以正常運作呢?有人會說,我們就是應該放ngOnInit裡面就行了,放建構函式裡面就是不行。那為啥不行呢,需要去弄清楚。

問題就是,Angular建構子和ngOnInit函式的差別是什麼呢?

區別一

語言上的差異:

先從語言的角度來看他們的差異。 ngOnInit只是組件類別上的一個方法,結構上和類別上的其他方法沒有什麼不同,只是有一個特定的名字。

export class MyMenuWidget implements OnInit { 
   ngOnInit() {}
}
登入後複製

實現不實現他都是可以的,我還可以這麼寫,完全沒有問題。無需顯示的標記要實現這個介面。

export class MyMenuWidget {
   ngOnInit() {}
}
登入後複製

這是ES6的寫法,上面的程式碼用ES5怎麼寫呢?

建構函式和他完全不一樣,他會在建立類別實例的時候會被呼叫。

export class MyMenuWidget {
   constructor(){}
  
   ngOnInit() {}
}
登入後複製

區別二

元件初始化過程的差異:

從元件初始化角度來看兩者的差別,還是很大的。 Angular的啟動過程有兩個主要階段:
1. 建構元件樹; 2. 執行變更偵測;

當Angular建構元件樹時候,需要建立元件實例,首先就會呼叫建構函式new 一個實例出來,也就是呼叫元件類別的建構子。然後調用,包括ngOnInit的所有生命週期鉤子都作為變更檢測階段的一部分被調用。

當Angular開始變更偵測時,元件樹已經建構好,並且已經呼叫樹中所有元件的建構子。此外,此時每個元件的模板節點都會加入DOM。在這裡,你可以使用初始化元件所需的所有資料——DI provider,DOM等。 @Input通訊機製作為變更檢測階段的一部分進行處理的,所以@Input在構造函數中不可用。

export class MyMenuWidget {
   constructor(private _elementRef: ElementRef){
     ...
   }
  
   ngOnInit() {}
}
登入後複製

區別三

功能上的差異:

對於Angular建構子,主要用來初始化,和注入依賴關係。通常的做法是,盡可能少放邏輯到建構函式中,有時候,儘管你放了很多邏輯但不影響功能。

對於ngOnInit,Angular在建立元件的DOM,使用建構函式註入所有必須的依賴,完成初始化後呼叫ngOnInit,這是執行元件初始化邏輯的好地方。

簡單的說 ,constructor建構子本身是和Angular無關的,ngOnInit這些鉤子函式是Angular裡定義的。

總結

現在是不是清楚為什麼@Input在建構子裡拿不到值的了吧。以後也清楚哪些邏輯放建構函式裡,哪些放ngOnInit裡了吧。

更多程式相關知識,請造訪:程式設計教學! !

以上是Angular開發問題記錄:元件拿不到@Input輸入屬性的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Angular學習之聊聊獨立組件(Standalone Component) Angular學習之聊聊獨立組件(Standalone Component) Dec 19, 2022 pm 07:24 PM

這篇文章帶大家繼續angular的學習,簡單了解一下Angular中的獨立組件(Standalone Component),希望對大家有幫助!

angular學習之詳解狀態管理器NgRx angular學習之詳解狀態管理器NgRx May 25, 2022 am 11:01 AM

這篇文章帶大家深入了解angular的狀態管理器NgRx,介紹一下NgRx的使用方法,希望對大家有幫助!

淺析Angular中的獨立組件,看看怎麼使用 淺析Angular中的獨立組件,看看怎麼使用 Jun 23, 2022 pm 03:49 PM

這篇文章帶大家了解Angular中的獨立元件,看看怎麼在Angular中建立一個獨立元件,怎麼在獨立元件中導入已有的模組,希望對大家有幫助!

專案過大怎麼辦?如何合理拆分Angular項目? 專案過大怎麼辦?如何合理拆分Angular項目? Jul 26, 2022 pm 07:18 PM

Angular專案過大,怎麼合理拆分它?以下這篇文章跟大家介紹一下合理分割Angular專案的方法,希望對大家有幫助!

聊聊自訂angular-datetime-picker格式的方法 聊聊自訂angular-datetime-picker格式的方法 Sep 08, 2022 pm 08:29 PM

怎麼自訂angular-datetime-picker格式?以下這篇文章聊聊自訂格式的方法,希望對大家有幫助!

手把手帶你了解Angular中的依賴注入 手把手帶你了解Angular中的依賴注入 Dec 02, 2022 pm 09:14 PM

這篇文章帶大家了解一下依賴注入,介紹一下依賴注入解決的問題和它原生的寫法是什麼,並聊聊Angular的依賴注入框架,希望對大家有所幫助!

深入了解Angular中的NgModule(模組) 深入了解Angular中的NgModule(模組) Sep 05, 2022 pm 07:07 PM

NgModule 模組是Angular種一個重要的點,因為Angular的基本構造塊就是NgModule。這篇文章就來帶大家了解Angular中的NgModule模組,希望對大家有幫助!

Angular專案如何上線?結合nginx來聊聊上線流程! Angular專案如何上線?結合nginx來聊聊上線流程! May 07, 2022 am 11:08 AM

Angular專案如何上線?以下這篇文章就來結合nginx聊聊Angular 專案的上線流程,希望對大家有幫助!

See all articles