搜尋
首頁web前端js教程使用 TanStack Angular Query 簡化 Angular v 中的 API 呼叫

本文提供了在 Angular v18 專案中使用穩定的 @tanstack/query-angular 套件進行高效 API 呼叫的指導?

管理 Angular 專案中的 API 互動通常涉及重複的邏輯,導致程式碼重複、增加維護負擔以及潛在的狀態管理複雜性。雖然 @tanstack/angular-query-experimental 提供了一個強大的解決方案,但值得注意的是,該套件仍處於實驗開發階段。相反,對於 Angular v17 項目,請考慮使用穩定的 @tanstack/angular-query-experimental 套件。

TanStack Angular Query 的主要優點:

聲明式方法:定義封裝 API 請求和相關資料處理的查詢函數,促進乾淨且可讀的程式碼。

自動快取和重新取得:利用內建快取策略(例如「stale-while-revalidate」)來最佳化效能並減少不必要的伺服器呼叫。根據您的需求(例如資料過時或視窗重新聚焦)實施資料重新獲取,以增強資料一致性。

反應式數據處理:使用可觀察量和訊號存取和管理數據,從而在 UI 元件中實現反應式更新,無需手動生命週期掛鉤或複雜的狀態管理模式。

模組化設計:將API邏輯組織成可重複使用的查詢實體,促進程式碼組織和可維護性。

專用開發工具:透過 TanStack 查詢開發工具深入了解查詢執行、快取狀態和重新取得模式,從而促進除錯和最佳化。

安裝:

使用npm或yarn安裝必要的套件:

npm install @tanstack/query-angular-experimental @tanstack/angular-query-devtools-experimental 

分步實施:

雖然 @tanstack/angular-query-experimental 可用於 Angular v17,但它目前處於實驗開發階段,不建議用於生產使用。為了在 Angular v17 專案中實現穩定可靠的 API 呼叫管理,請考慮使用穩定的 @tanstack/query-angular 套件。

這是逐步實施指南:

1.在app.config.ts中加入Provider:

import { ApplicationConfig } from '@angular/core';
import { provideRouter } from '@angular/router';

import { routes } from './app.routes';
import { provideHttpClient } from '@angular/common/http';
import { QueryClient, provideAngularQuery } from '@tanstack/angular-query-experimental';

const queryClient = new QueryClient();

export const appConfig: ApplicationConfig = {
  providers: [
    provideRouter(routes),
    provideHttpClient(),
    provideAngularQuery(queryClient)
  ]
};
  • 導入provideHttpClient、QueryClient、provideAngularQuery。
  • 透過依賴注入提供路由、HTTP 和 Angular Query 功能來定義和匯出應用程式配置物件。

2. 為 API 回應定義基於 Typescript 的類型:

類型在 TypeScript 中用於指定資料的結構和類型,有助於程式碼組織和錯誤預防。在您的 Angular 應用程式中,此類型可能會作為建立從 API 或其他資料來源檢索的​​資料的藍圖。

npm install @tanstack/query-angular-experimental @tanstack/angular-query-devtools-experimental 

3.定義一個Service repos.service.ts來消費API呼叫:

import { ApplicationConfig } from '@angular/core';
import { provideRouter } from '@angular/router';

import { routes } from './app.routes';
import { provideHttpClient } from '@angular/common/http';
import { QueryClient, provideAngularQuery } from '@tanstack/angular-query-experimental';

const queryClient = new QueryClient();

export const appConfig: ApplicationConfig = {
  providers: [
    provideRouter(routes),
    provideHttpClient(),
    provideAngularQuery(queryClient)
  ]
};

該服務負責向 GitHub API 發出 HTTP 請求以取得儲存庫資料。它使用 HttpClient 發出請求,並期望回應資料符合 Response 類型中定義的結構。

4. 在元件 github-repo-list.component.ts 中啟動 Angular Query:

元件使用 Angular Query 來管理資料擷取和快取。它注入 ReposService 來進行 API 呼叫。它定義了一個具有唯一鍵“repoData”的查詢,以使用 queryFn 獲取存儲庫資料。

export type Response = {
  name: string
  description: string
  subscribers_count: number
  stargazers_count: number
  forks_count: number
}

5. 讓我們在元件 UI github-repo-list.component.html 中渲染資料:

import { HttpClient } from '@angular/common/http';
import { Injectable } from '@angular/core';
import { Response } from '../../types/responce.type';

@Injectable({
  providedIn: 'root'
})
export class ReposService {

  endpoint: string = 'https://api.github.com';

  constructor(
    private http: HttpClient
  ) { }

  getRepos() {
    return this.http.get<response>(`${this.endpoint}/repos/tanstack/query`);
  }
}
</response>
  • 此範本根據查詢的狀態有條件地呈現不同的內容:載入、錯誤或成功。
  • 它有效地處理不同的場景,為使用者提供適當的回饋。
  • 它包含用於偵錯和檢查的 Angular Query 開發工具。

工作演示:

Streamlining API Calls in Angular vwith TanStack Angular Query

在 Github 上查看完整的原始碼。謝謝?

以上是使用 TanStack Angular Query 簡化 Angular v 中的 API 呼叫的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
在JavaScript中替換字符串字符在JavaScript中替換字符串字符Mar 11, 2025 am 12:07 AM

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

jQuery檢查日期是否有效jQuery檢查日期是否有效Mar 01, 2025 am 08:51 AM

簡單JavaScript函數用於檢查日期是否有效。 function isValidDate(s) { var bits = s.split('/'); var d = new Date(bits[2] '/' bits[1] '/' bits[0]); return !!(d && (d.getMonth() 1) == bits[1] && d.getDate() == Number(bits[0])); } //測試 var

jQuery獲取元素填充/保證金jQuery獲取元素填充/保證金Mar 01, 2025 am 08:53 AM

本文探討如何使用 jQuery 獲取和設置 DOM 元素的內邊距和外邊距值,特別是元素外邊距和內邊距的具體位置。雖然可以使用 CSS 設置元素的內邊距和外邊距,但獲取準確的值可能會比較棘手。 // 設定 $("div.header").css("margin","10px"); $("div.header").css("padding","10px"); 你可能會認為這段代碼很

10個jQuery手風琴選項卡10個jQuery手風琴選項卡Mar 01, 2025 am 01:34 AM

本文探討了十個特殊的jQuery選項卡和手風琴。 選項卡和手風琴之間的關鍵區別在於其內容面板的顯示和隱藏方式。讓我們深入研究這十個示例。 相關文章:10個jQuery選項卡插件

10值得檢查jQuery插件10值得檢查jQuery插件Mar 01, 2025 am 01:29 AM

發現十個傑出的jQuery插件,以提升您的網站的活力和視覺吸引力!這個精選的收藏品提供了不同的功能,從圖像動畫到交互式畫廊。讓我們探索這些強大的工具:相關文章:1

HTTP與節點和HTTP-Console調試HTTP與節點和HTTP-Console調試Mar 01, 2025 am 01:37 AM

HTTP-Console是一個節點模塊,可為您提供用於執行HTTP命令的命令行接口。不管您是否針對Web服務器,Web Serv

自定義Google搜索API設置教程自定義Google搜索API設置教程Mar 04, 2025 am 01:06 AM

本教程向您展示瞭如何將自定義的Google搜索API集成到您的博客或網站中,提供了比標準WordPress主題搜索功能更精緻的搜索體驗。 令人驚訝的是簡單!您將能夠將搜索限制為Y

jQuery添加捲軸到DivjQuery添加捲軸到DivMar 01, 2025 am 01:30 AM

當div內容超出容器元素區域時,以下jQuery代碼片段可用於添加滾動條。 (無演示,請直接複製到Firebug中) //D = document //W = window //$ = jQuery var contentArea = $(this), wintop = contentArea.scrollTop(), docheight = $(D).height(), winheight = $(W).height(), divheight = $('#c

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

記事本++7.3.1

記事本++7.3.1

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

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具