Rumah >hujung hadapan web >tutorial js >## Bagaimanakah Saya Boleh Mengoptimumkan Prestasi Penghalaan Sudut 2 dengan Menyimpan dan Membuang Laluan Terpilih?

## Bagaimanakah Saya Boleh Mengoptimumkan Prestasi Penghalaan Sudut 2 dengan Menyimpan dan Membuang Laluan Terpilih?

DDD
DDDasal
2024-10-25 22:09:03963semak imbas

## How Can I Optimize Angular 2 Routing Performance by Selectively Storing and Discarding Routes?

Menyimpan dan Membuang Laluan Tertentu dengan RouteReuseStrategy dalam Angular 2

Pernyataan Masalah

Apabila melaksanakan penghalaan dalam aplikasi Angular 2, anda mungkin mahukan laluan tertentu untuk disimpan dalam ingatan untuk pemaparan yang lebih pantas selepas melawat semula. Walau bagaimanapun, untuk sesetengah laluan, seperti paparan terperinci sumber, anda mungkin memilih untuk membuangnya daripada memori untuk menjimatkan sumber.

Gambaran Keseluruhan Penyelesaian

Angular 2 menyediakan antara muka RouteReuseStrategy untuk mengawal penyimpanan dan mendapatkan semula laluan. Dengan melaksanakan antara muka ini dan menyediakannya dalam modul Angular anda, anda boleh menentukan gelagat tersuai untuk masa laluan harus disimpan dan bila laluan harus dibuang.

Melaksanakan RouteReuseStrategy

shouldDetach

Dalam kaedah shouldDetach, anda boleh menentukan sama ada laluan harus disimpan. Jika ia kembali benar, Angular akan menyimpan laluan. Biasanya, anda akan menyemak laluan laluan dan memutuskan sama ada untuk menyimpannya atau tidak berdasarkan satu set kriteria yang telah ditetapkan.

simpan

Jika shouldDetach kembali benar, kaedah stor dipanggil untuk menyimpan laluan. Anda boleh melaksanakan kaedah ini untuk menyimpan ActivatedRouteSnapshot dan DetachedRouteHandle, yang akan digunakan kemudian untuk digunakan semula.

shouldAttach

Dalam kaedah shouldAttach, anda boleh menyemak sama ada laluan perlu digunakan semula. Jika ia kembali benar, Angular akan menggunakan versi laluan yang disimpan dan tidak membuat yang baharu. Anda boleh menggunakan ActivatedRouteSnapshot dan queryParams untuk membandingkan laluan masuk dengan sifat laluan yang disimpan untuk menentukan sama ada ia sepadan.

mendapatkan semula

Jika shouldAttach mengembalikan benar, kaedah dapatkan semula dipanggil untuk mendapatkan semula versi yang disimpan daripada laluan itu. Anda boleh menggunakan DetachedRouteHandle yang disimpan oleh kedai untuk mengenal pasti dan mengembalikan laluan yang betul.

Contoh Penggunaan

Sebagai contoh, pertimbangkan aplikasi tempat anda ingin menyimpan halaman hasil carian, tetapi bukan individu halaman butiran sumber. Begini cara anda melaksanakannya:

<code class="typescript">import { ActivatedRouteSnapshot, RouteReuseStrategy, DetachedRouteHandle } from '@angular/router';

export class CustomRouteReuseStrategy implements RouteReuseStrategy {
  private storedRoutes: { [key: string]: RouteStorageObject } = {};

  shouldDetach(route: ActivatedRouteSnapshot): boolean {
    if (route.routeConfig.path === 'search/:term') {
      return true;
    }
    return false;
  }

  store(route: ActivatedRouteSnapshot, handle: DetachedRouteHandle): void {
    if (shouldDetach(route)) {
      this.storedRoutes[route.routeConfig.path] = { snapshot: route, handle };
    }
  }

  shouldAttach(route: ActivatedRouteSnapshot): boolean {
    if (this.storedRoutes.hasOwnProperty(route.routeConfig.path)) {
      return true;
    }
    return false;
  }

  retrieve(route: ActivatedRouteSnapshot): DetachedRouteHandle {
    if (shouldAttach(route)) {
      return this.storedRoutes[route.routeConfig.path].handle;
    }
    return null;
  }

  shouldReuseRoute(future: ActivatedRouteSnapshot, curr: ActivatedRouteSnapshot): boolean {
    return future.routeConfig === curr.routeConfig;
  }
}</code>

Dalam AppModule:

<code class="typescript">@NgModule({
  [...],
  providers: [
    { provide: RouteReuseStrategy, useClass: CustomRouteReuseStrategy }
  ]
})
export class AppModule {}</code>

Dengan menyediakan strategi ini, Angular akan mengurus penyimpanan dan mendapatkan semula laluan secara automatik berdasarkan peraturan yang anda tentukan , membolehkan prestasi dioptimumkan dalam aplikasi anda.

Atas ialah kandungan terperinci ## Bagaimanakah Saya Boleh Mengoptimumkan Prestasi Penghalaan Sudut 2 dengan Menyimpan dan Membuang Laluan Terpilih?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn