欧美亚洲中文,在线国自产视频,欧洲一区在线观看视频,亚洲综合中文字幕在线观看

      1. <dfn id="rfwes"></dfn>
          <object id="rfwes"></object>
        1. 站長資訊網(wǎng)
          最全最豐富的資訊網(wǎng)站

          Angular學(xué)習(xí)之聊聊獨立組件(Standalone Component)

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

          Angular學(xué)習(xí)之聊聊獨立組件(Standalone Component)

          Angular 14一項令人興奮的特性就是Angular的獨立組件(Standalone Component)終于來了?!鞠嚓P(guān)教程推薦:《angular教程》】

          在Angular 14中, 開發(fā)者可以嘗試使用獨立組件開發(fā)各種組件,但是值得注意的是Angular獨立組件的API仍然沒有穩(wěn)定下,將來可能存在一些破壞性更新,所以不推薦在生產(chǎn)環(huán)境中使用。

          基本使用

          angular.io/guide/stand…

          standalone 是 Angular14 推出的新特性。

          它可以讓你的 根模塊 AppModule 不至于那么臃腫

          所有的 component / pipe / directive 都在被使用的時候 在對應(yīng)的組件引入就好了

          舉個例子 這是之前的寫法 我們聲明一個 Footer 組件

          然后在使用的 Module 中導(dǎo)入這個組件

          import { Component } from '@angular/core';  @Component({   selector: 'app-footer',   template: ` <footer class="dark:bg-gray-800 dark:text-gray-50">Footer</footer> `, }) export class FooterComponent {}
          登錄后復(fù)制

          import { NgModule } from '@angular/core'; import { CommonModule } from '@angular/common'; import { FooterComponent } from './footer.component';  @NgModule({   declarations: [HomeComponent, FooterComponent],   exports: [],   imports: [CommonModule], }) export class AppModuleModule {}
          登錄后復(fù)制

          這種寫法導(dǎo)致我們始終無法擺脫 NgModule

          但其實我們的意圖就是在 AppComponent 中使用 FooterComponent

          換成 React 中的寫法 其實會更便于管理和理解

          用上我們的新特性 standalone

          Footer 組件就改造成這樣

          import { Component } from '@angular/core';  @Component({   selector: 'app-footer',   // 將該組件聲明成獨立組件   standalone: true,   template: ` <footer class="dark:bg-gray-800 dark:text-gray-50">Footer</footer> `, }) export class FooterComponent {}
          登錄后復(fù)制

          然后比如在 Home 頁面 我們就可以這樣使用

          import { Component } from '@angular/core';  import { FooterComponent } from '@components/footer/footer.component';  @Component({   selector: 'app-home',   standalone: true,   // 聲明需要使用的 component / pipe / directive 但是它們也必須都是獨立組件   imports: [FooterComponent],   template: `<app-footer></app-footer>`, }) export class WelcomeComponent {}
          登錄后復(fù)制

          獨立組件可以直接用于懶加載 本來我們必須借助 NgModule 來實現(xiàn)

          import { NgModule } from '@angular/core'; import { RouterModule, Routes } from '@angular/router';  import { CustomPreloadingStrategy } from '@views/basic-syntax/router/customPreloadingStrategy';  const routes: Routes = [   {     path: 'home',     // 之前想要實現(xiàn)懶加載 這里必須是一個NgModule 現(xiàn)在使用獨立組件也可以 并且更加簡潔     loadComponent: () => import('@views/home/home.component').then((mod) => mod.HomeComponent),   }, ];  @NgModule({   imports: [RouterModule.forRoot(routes, { preloadingStrategy: CustomPreloadingStrategy })],   exports: [RouterModule], }) export class AppRoutingModule {}
          登錄后復(fù)制

          贊(0)
          分享到: 更多 (0)
          網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號