在軟體開發的世界中,我們常發現自己在兩個範式之間左右為難:指令式和聲明式。對於許多開發人員來說,命令式程式碼的吸引力在於它的簡單性——只需逐步編寫指令,您就可以確切地知道電腦在做什麼。然而,隨著複雜性的增加,這種循序漸進的方法變成了分散在程式碼庫中的混亂的邏輯。相較之下,聲明式方法旨在讓您描述您想要什麼,而不是如何獲得它,從而將您從微觀管理細節中解放出來。
在這篇文章中,我們並不是想要證明聲明式是「最佳」方法。相反,我們將探索聲明式設計如何創建一個尊重您作為開發人員的智慧的系統,使您能夠優雅地擴展您的應用程式並以少得多的認知開銷來維護它。
假設您正在建立一個小型應用程式來從各種 API 取得貼文和使用者。命令式方式可能如下圖所示:
乍一看,這很簡單——只需執行 GET 請求並返回資料即可。但當複雜性逐漸增加時會發生什麼?您可能需要:
您很快就會發現自己在各處複製和貼上程式碼、硬編碼端點和標頭,並手動管理複雜的邏輯網路。命令式風格開始感覺像是一件苦差事:您一次又一次地編寫相同的指令,並且很容易忘記所有邏輯所在的位置。
現在讓我們來看看更具聲明性的設計。您無需告訴系統如何取得每個資源,而是描述什麼每個資源的外觀、它所在的位置以及它與其他資源的關係。然後,您讓靈活的轉接器或管理器處理幕後的細節。
這是一個例子:
乍一看,這可能看起來更複雜,因為我們有類別、靜態屬性和適配器。但仔細看看:
換句話說,您正在建立一個讀起來更像是一組聲明而不是一組指令的系統。適配器和模型形成了其餘程式碼可以依賴的模式,而不是隨機 axios.get() 呼叫的臨時叢集。
為什麼要付出這樣的努力?因為隨著專案的成長,您不想浪費時間在命令式邏輯的雷區中航行。聲明式設計設定期望:
這種方法尊重您作為開發人員的智慧。它不會強迫您回憶哪個端點屬於哪個模型或定義標頭的位置。相反,它讓您在更高的層次上思考:定義資料的外觀及其關聯方式,然後讓框架處理其餘的內容。
我們並不是說帶有適配器和靜態欄位的聲明式方法普遍優於原始命令式程式碼。對於小腳本,axios.get() 可能就滿足您的需求。但隨著系統規模的擴大,聲明式方法會創建一個可持續的環境,其中更改不會那麼痛苦,功能更容易添加,並且總體複雜性得到妥善管理。
你可以說這是關於建立一個系統,讓你(開發人員)更像一個聰明的工程師,而不是一個指令轉錄員。
如果您習慣於手寫每一步,那麼聲明式方法一開始可能會感覺很陌生。但是,一旦您體驗到擁有一致的模式、明確聲明的端點以及整齊地添加自訂邏輯的位置的平靜,就很難再回到命令式蔓延。
這不是為了證明優越性。這是為了提供一種對未來的自己更友善、更尊重你的時間、更符合你對數據和關係的看法的方法。您不必對每個請求進行微觀管理,而是編寫讀起來像故事的程式碼,專注於您想要的什麼,而不是如何獲得它的每個乏味細節。
以上是採用聲明式資料存取來尊重您作為開發人員的智慧的詳細內容。更多資訊請關注PHP中文網其他相關文章!