首頁 >web前端 >js教程 >採用聲明式資料存取來尊重您作為開發人員的智慧

採用聲明式資料存取來尊重您作為開發人員的智慧

Susan Sarandon
Susan Sarandon原創
2024-12-18 16:57:09612瀏覽

Embracing Declarative Data Access to Respect Your Intelligence as a Developer

在軟體開發的世界中,我們常發現自己在兩個範式之間左右為難:指令式聲明式。對於許多開發人員來說,命令式程式碼的吸引力在於它的簡單性——只需逐步編寫指令,您就可以確切地知道電腦在做什麼。然而,隨著複雜性的增加,這種循序漸進的方法變成了分散在程式碼庫中的混亂的邏輯。相較之下,聲明式方法旨在讓您描述您想要什麼,而不是如何獲得它,從而將您從微觀管理細節中解放出來。

在這篇文章中,我們並不是想要證明聲明式是「最佳」方法。相反,我們將探索聲明式設計如何創建一個尊重您作為開發人員的智慧的系統,使您能夠優雅地擴展您的應用程式並以少得多的認知開銷來維護它。


勢在必行:詳細說明之路

假設您正在建立一個小型應用程式來從各種 API 取得貼文和使用者。命令式方式可能如下圖所示:

乍一看,這很簡單——只需執行 GET 請求並返回資料即可。但當複雜性逐漸增加時會發生什麼?您可能需要:

  • 不同模型的多個端點。
  • 身份驗證標頭。
  • 分頁、過濾和複雜查詢。
  • 資料驗證和模型之間的關係。

您很快就會發現自己在各處複製和貼上程式碼、硬編碼端點和標頭,並手動管理複雜的邏輯網路。命令式風格開始感覺像是一件苦差事:您一次又一次地編寫相同的指令,並且很容易忘記所有邏輯所在的位置。


聲明式:意圖與模式的世界

現在讓我們來看看更具聲明性的設計。您無需告訴系統如何取得每個資源,而是描述什麼每個資源的外觀、它所在的位置以及它與其他資源的關係。然後,您讓靈活的轉接器或管理器處理幕後的細節。

這是一個例子:

乍一看,這可能看起來更複雜,因為我們有類別、靜態屬性和適配器。但仔細看看:

  • 到處都沒有硬編碼的 URL:基本 URL、端點和標頭在類別層級定義一次。對該模型的任何請求都會自動使用這些預設值。
  • 聲明關係,而非強制:CustomUser 定義了一個 _post 方法,該方法傳回與使用者相關的貼文。這感覺幾乎就像一個查詢,而不是一堆命令式程式碼。您正在陳述您的意圖:「我想要該用戶的貼文。」
  • 輕鬆擴充和自訂:需要自訂邏輯來取得貼文?只需重寫 PostAdapter 中的 all() 即可。透過使此邏輯成為預設行為的乾淨擴展,您可以減少意外破壞其他內容的機會。

換句話說,您正在建立一個讀起來更像是一組聲明而不是一組指令的系統。適配器和模型形成了其餘程式碼可以依賴的模式,而不是隨機 axios.get() 呼叫的臨時叢集。


真正的勝利:尊重開發者的智慧

為什麼要付出這樣的努力?因為隨著專案的成長,您不想浪費時間在命令式邏輯的雷區中航行。聲明式設計設定期望:

  • 當您看到 CustomUser.objects.all() 時,您立即知道它的意義:它會傳回所有 CustomUser 實例的迭代器。無需猜測。
  • 當你聲明 static adapter = UserAdapter; 時,你就知道 CustomUser 上的任何資料操作都會在幕後使用 UserAdapter。一致性和清晰度是內建的。
  • 當您在模型上定義靜態模式時,您可以相信系統知道如何驗證或處理這些字段,而無需重新編寫重複的命令性程式碼。

這種方法尊重您作為開發人員的智慧。它不會強迫您回憶哪個端點屬於哪個模型或定義標頭的位置。相反,它讓您在更高的層次上思考:定義資料的外觀及其關聯方式,然後讓框架處理其餘的內容。


不是“最好”,而是可持續發展

我們並不是說帶有適配器和靜態欄位的聲明式方法普遍優於原始命令式程式碼。對於小腳本,axios.get() 可能就滿足您的需求。但隨著系統規模的擴大,聲明式方法會創建一個可持續的環境,其中更改不會那麼痛苦,功能更容易添加,並且總體複雜性得到妥善管理。

你可以說這是關於建立一個系統,讓你(開發人員)更像一個聰明的工程師,而不是一個指令轉錄員。


結論

如果您習慣於手寫每一步,那麼聲明式方法一開始可能會感覺很陌生。但是,一旦您體驗到擁有一致的模式、明確聲明的端點以及整齊地添加自訂邏輯的位置的平靜,就很難再回到命令式蔓延。

這不是為了證明優越性。這是為了提供一種對未來的自己更友善、更尊重你的時間、更符合你對數據和關係的看法的方法。您不必對每個請求進行微觀管理,而是編寫讀起來像故事的程式碼,專注於您想要的什麼,而不是如何獲得它的每個乏味細節。

以上是採用聲明式資料存取來尊重您作為開發人員的智慧的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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