Rumah >hujung hadapan web >tutorial js >Analisis ringkas komponen bebas dalam Angular dan lihat cara menggunakannya
Artikel ini akan membawa anda melalui komponen bebas dalam Angular, cara mencipta komponen bebas dalam Angular dan cara mengimport modul sedia ada dalam komponen bebas saya harap ia akan membantu semua orang. !
Ciri menarik Angular 14 ialah komponen bebas Angular akhirnya berada di sini.
Dalam Angular 14, pembangun boleh cuba menggunakan komponen bebas untuk membangunkan pelbagai komponen, tetapi perlu diperhatikan bahawa API komponen bebas Angular masih tidak stabil, dan mungkin terdapat beberapa kemas kini yang merosakkan pada masa hadapan, jadi ia tidak digalakkan digunakan dalam persekitaran pengeluaran. [Cadangan tutorial berkaitan: "tutorial sudut"]
Untuk komponen sedia ada, kami boleh @Component()
Tambah berdiri sendiri: benar, dan kemudian kami boleh terus menggunakan @NgModule()
untuk mengimport modul lain tanpa imports
.
Jika anda mencipta komponen baharu, anda boleh menggunakan perintah ng generate component <name> --standalone</name>
untuk mencipta komponen bebas secara terus, contohnya:
ng generate component button-list --standalone
@Component({ selector: 'app-button-list', standalone: true, imports: [ CommonModule, ], templateUrl: './button-list.component.html', styleUrls: ['./button-list.component.scss'] }) export class ButtonListComponent implements OnInit
Kita boleh menambah modul sedia ada dalam imports
, ambil MatButtonModule
sebagai contoh:
imports: [ CommonModule, MatButtonModule, ],
Dengan cara ini, kita boleh menggunakan ButtonListComponent
's MatButtonModule > Komponen: mat-button
<button mat-button>Basic</button> <button mat-button color="primary">Primary</button> <button mat-button color="accent">Accent</button> <button mat-button color="warn">Warn</button> <button mat-button disabled>Disabled</button> <a mat-button href="https://damingerdai.github.io" target="_blank">Link</a>Rendering:
sebagai komponen bebas: AppComponent
@Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.scss'], standalone: true, }) export class AppComponent {Langkah kedua, tambahkan modul yang diimport dalam import
kepada import AppModule
, tetapi terdapat dua modul Pengecualian: AppComponent
dan BrowserModule
. BrowserAnimationsModule
telah pun dimuatkan Jika anda memerlukan akses kepada arahan biasa seperti NgIf dan NgFor, import BrowserModule
sebaliknya.** masalah: CommonModule
<.>
Langkah ketiga ialah memadam fail
app.module.ts
Langkah terakhir ialah menukar perkataan dalam
main.ts
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'; platformBrowserDynamic().bootstrapModule(AppModule) .catch(err => console.error(err));Dengan cara ini, kita boleh memulakan komponen Sudut menggunakan komponen bebas.
bootstrapApplication(AppComponent).catch(err => console.error(err));Konfigurasikan penghalaan untuk komponen bebas
dan HomeComponent
, ButtonListComponent
ChipListComponent
kemudian Cipta objek
main.ts
dalam
const ROUTES: Route[] = [ { path: '', pathMatch: 'full', redirectTo: 'home' }, { path: 'home', component: HomeComponent }, { path: 'button', loadComponent: () => import('./app/button-list/button-list.component').then( (mod) => mod.ButtonListComponent ), }, { path: 'chip', loadComponent: () => import('./app/chip-list/chip-list.component').then( (mod) => mod.ChipListComponent ), }, ];dan
menggunakan ButtonListComponent
untuk melaksanakan pemuatan malas laluan. ChipListComponent
loadComponent
Kemudian gunakan
dalam parameter kedua bootstrapApplication
. providers
RouterModule
bootstrapApplication(AppComponent, { providers: [ importProvidersFrom(RouterModule.forRoot([...ROUTES])), ], }).catch(err => console.error(err));Mengkonfigurasi Suntikan Ketergantungan
. bootstrapApplication
providers
Sebagai contoh, saya mempunyai url untuk mendapatkan gambar, yang perlu disuntik ke dalam
PhotoService
bootstrapApplication(AppComponent, { providers: [ { provide: 'photoUrl', useValue: 'https://picsum.photos', }, {provide: PhotosService, useClass: PhotosService }, importProvidersFrom(RouterModule.forRoot([...ROUTES])), importProvidersFrom(HttpClientModule) ], })Kodnya adalah seperti berikut:
PhotoService
@Injectable()export class PhotosService { constructor( @Inject('photoUrl') private photoUrl: string, private http: HttpClient ) { } public getPhotoUrl(i: number): string { return `${this.photoUrl}/200/300?random=${i}`; } }Kod sumber
Demo dalam talian : https:// damingerdai.github.io/angular-standalone-components-app/
Alamat asal: https://juejin.cn/post/7107224235914821662Lebih banyak pengaturcaraan berkaitan Untuk pengetahuan, sila layari:Video Pengaturcaraan
Atas ialah kandungan terperinci Analisis ringkas komponen bebas dalam Angular dan lihat cara menggunakannya. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!